青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

POJ 3414

http://acm.pku.edu.cn/JudgeOnline/problem?id=3414
又是一道廣搜題,可這次卻有個不一樣的地方,除了求出最短步數外,還要輸出最短路徑出來。在原來結點的基礎上,增加pre和flag兩個變量,分別記錄父結點在隊列中的位置和進行哪種操作。記錄最短路徑讓我費了一些周折。看來這里還是不很熟悉,以后得多加練習和思考c
  1 #include<stdio.h>
  2 #include<string.h>
  3 #include<stdlib.h>
  4 int a,b,c;
  5 typedef struct node{
  6     int liter1,liter2,step,pre,flag;
  7 }Node;
  8 typedef struct queue{
  9     Node q[11000];
 10     int front,rear;
 11 }Queue;
 12 Queue Q;
 13 int path[11000],j;
 14 int visit[101][101];
 15 void bfs();
 16 int main()
 17 {
 18     while(scanf("%d%d%d",&a,&b,&c) != EOF)
 19         bfs();
 20     system("pause");
 21     return 0;
 22 }
 23 
 24 void bfs()
 25 {
 26     Node pot;
 27     Node lx,lc;
 28     memset(visit,0,sizeof(visit));
 29     pot.liter1 = 0;
 30     pot.liter2 = 0;
 31     pot.step = 0;
 32     pot.pre = -1;
 33     Q.front = Q.rear = 1;
 34     Q.q[Q.rear++= pot;
 35     visit[0][0= 1;
 36     while(Q.front != Q.rear){
 37         lc = Q.q[Q.front++];
 38         if(lc.liter1 == c || lc.liter2 == c)break;
 39         for(int i = 1;i < 7;i++){
 40             if(i == 1){
 41                 lx.liter1 = a;
 42                 lx.liter2 = lc.liter2;
 43                 lx.step = lc.step + 1;
 44                 lx.pre = Q.front-1;
 45                 lx.flag = i;
 46                 if(visit[lx.liter1][lx.liter2] == 0){
 47                     visit[lx.liter1][lx.liter2] = 1;
 48                     Q.q[Q.rear++= lx;
 49                 }
 50             }
 51             if(i == 2){
 52                 lx.liter1 = lc.liter1;
 53                 lx.liter2 = b;
 54                 lx.step = lc.step + 1;
 55                 lx.pre = Q.front-1;
 56                 lx.flag = i;
 57                 if(visit[lx.liter1][lx.liter2] == 0){
 58                     visit[lx.liter1][lx.liter2] = 1;
 59                     Q.q[Q.rear++= lx;
 60                 }
 61             }
 62             if(i == 3){
 63                 lx.liter1 = 0;
 64                 lx.liter2 = lc.liter2;
 65                 lx.step = lc.step + 1;
 66                 lx.pre = Q.front-1;
 67                 lx.flag = i;
 68                 if(visit[lx.liter1][lx.liter2] == 0){
 69                     visit[lx.liter1][lx.liter2] = 1;
 70                     Q.q[Q.rear++= lx;
 71                 }
 72             }
 73             if(i == 4){
 74                 lx.liter1 = lc.liter1;
 75                 lx.liter2 = 0;
 76                 lx.step = lc.step + 1;
 77                 lx.pre = Q.front-1;
 78                 lx.flag = i;
 79                 if(visit[lx.liter1][lx.liter2] == 0){
 80                     visit[lx.liter1][lx.liter2] = 1;
 81                     Q.q[Q.rear++= lx;
 82                 }
 83             }
 84             if(i == 5){//2 to 1
 85                 if(lc.liter1 + lc.liter2 > a){
 86                     lx.liter1 = a;
 87                     lx.liter2 = lc.liter1 + lc.liter2 - a;
 88                 }
 89                 else{
 90                     lx.liter1 = lc.liter1 + lc.liter2;
 91                     lx.liter2 = 0;
 92                 }
 93                 lx.step = lc.step + 1;
 94                 lx.pre = Q.front-1;
 95                 lx.flag = i;
 96                 
 97                 if(visit[lx.liter1][lx.liter2] == 0){
 98                     visit[lx.liter1][lx.liter2] = 1;
 99                     Q.q[Q.rear++= lx;
100                 }
101             }
102             if(i == 6){//1 to 2
103                 if(lc.liter1 + lc.liter2 > b){
104                     lx.liter1 = lc.liter1 + lc.liter2 - b;
105                     lx.liter2 = b;
106                 }
107                 else{
108                     lx.liter1 = 0;
109                     lx.liter2 = lc.liter1 + lc.liter2;
110                 }
111                 lx.step = lc.step + 1;
112                 lx.pre = Q.front-1;
113                 lx.flag = i;
114                 
115                 if(visit[lx.liter1][lx.liter2] == 0){
116                     visit[lx.liter1][lx.liter2] = 1;
117                     Q.q[Q.rear++= lx;
118                 }
119             }
120         }
121     }
122     if(Q.front == Q.rear){
123         printf("impossible\n");
124         return;
125     }
126     j = 0;
127     for(int i = Q.front-1;i>=0;){
128         path[j++= i;
129         i = Q.q[i].pre;
130     }
131     printf("%d\n",Q.q[Q.front-1].step);
132     for(int i = j-1;i>= 0;i--){
133         switch(Q.q[path[i]].flag){
134             case 1:printf("FILL(1)\n");break;
135             case 2:printf("FILL(2)\n");break;
136             case 3:printf("DROP(1)\n");break;
137             case 4:printf("DROP(2)\n");break;
138             case 5:printf("POUR(2,1)\n");break;
139             case 6:printf("POUR(1,2)\n");break;
140         }
141     }
142         
143 }
code

posted on 2009-06-09 11:27 Johnnx 閱讀(432) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


導航

<2009年9月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910

統計

常用鏈接

留言簿(1)

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧美成人网| 亚洲一区二区三区视频播放| 久久五月婷婷丁香社区| 欧美一区二区网站| 国产亚洲欧洲| 欧美成人中文| 欧美激情综合五月色丁香| 99re6这里只有精品视频在线观看| 亚洲国产精品精华液2区45| 欧美激情亚洲视频| 一区二区三区高清不卡| 亚洲一区免费在线观看| 国产综合久久久久影院| 欧美二区不卡| 欧美日韩在线不卡| 久久久精品视频成人| 巨乳诱惑日韩免费av| 亚洲神马久久| 欧美在线视频播放| 亚洲久久一区| 亚洲欧美影院| 亚洲国产一二三| 中日韩视频在线观看| 国产尤物精品| 亚洲免费av片| 在线欧美视频| 亚洲一二三区精品| 亚洲日本中文字幕免费在线不卡| 99在线精品视频| 亚洲第一黄网| 国产精品99久久久久久宅男| 在线观看中文字幕亚洲| 中日韩美女免费视频网址在线观看| 国内精品模特av私拍在线观看| 欧美激情第三页| 国产欧美日韩精品在线| 亚洲精品久久久久久一区二区| 国产精品乱码一区二三区小蝌蚪| 欧美福利精品| 国产原创一区二区| 亚洲图片你懂的| 亚洲精品一级| 久久一二三区| 久久久久国产精品www| 欧美视频1区| 亚洲国产精品精华液2区45| 国产在线精品成人一区二区三区| 亚洲人成人一区二区三区| 国产综合精品| 久久99在线观看| 欧美在线视频观看| 欧美性久久久| 夜夜嗨av一区二区三区中文字幕| 亚洲激情国产精品| 久久精品国产欧美激情| 久久精品一区四区| 国产精品一区=区| 在线一区二区日韩| 亚洲一区二区高清视频| 欧美另类高清视频在线| 亚洲丶国产丶欧美一区二区三区| 一区二区在线观看视频| 亚欧成人在线| 久久精品一区二区三区四区| 国产欧美日韩免费| 亚洲欧美日韩另类| 久久黄色级2电影| 国产乱码精品1区2区3区| 一区二区三区蜜桃网| 亚洲一区二区伦理| 国产精品久久二区| 亚洲一区bb| 久久国产一区二区| 狠狠色伊人亚洲综合成人| 亚洲免费视频观看| 久久久精品国产免大香伊| 国产综合视频在线观看| 久久久av水蜜桃| 欧美大片在线看| 亚洲黄色在线观看| 欧美理论视频| 亚洲先锋成人| 久久精品女人| 在线观看一区视频| 欧美激情成人在线| 99精品国产高清一区二区| 一本久久精品一区二区| 国产精品成人国产乱一区| 亚洲综合电影| 嫩模写真一区二区三区三州| 亚洲国产欧美在线人成| 欧美日韩一区二区欧美激情| 亚洲欧美日韩精品久久久久| 免费欧美视频| 亚洲一区欧美| 狠狠久久婷婷| 欧美日韩一区二区精品| 久久gogo国模裸体人体| 亚洲国产日韩一级| 午夜在线精品| 亚洲韩国青草视频| 国产精品一级久久久| 久久亚洲精品一区二区| 日韩一区二区精品| 麻豆免费精品视频| 在线亚洲一区| 在线电影欧美日韩一区二区私密| 欧美精品在线一区二区| 欧美影院精品一区| 亚洲免费观看| 欧美电影在线播放| 欧美亚洲视频在线观看| 亚洲毛片在线观看| 国产在线观看一区| 欧美新色视频| 欧美精品成人一区二区在线观看| 午夜欧美大尺度福利影院在线看 | 国产伦理一区| 免费欧美日韩| 欧美在线免费观看亚洲| 一区二区高清在线观看| 欧美激情视频在线播放| 久久精品国产99| 亚洲一级黄色| 亚洲美女在线国产| 亚洲福利视频免费观看| 国产视频精品xxxx| 国产精品伦子伦免费视频| 欧美黄色免费网站| 免播放器亚洲一区| 久久久av毛片精品| 欧美影院在线| 亚洲欧美日韩中文视频| 99视频精品在线| 亚洲国产91精品在线观看| 免费亚洲电影在线| 久久亚洲二区| 老**午夜毛片一区二区三区| 久久久精品免费视频| 久久精精品视频| 久久精品亚洲精品| 欧美一区二区私人影院日本| 亚洲欧美日本在线| 午夜精品福利一区二区蜜股av| 亚洲午夜av电影| 亚洲一区日韩在线| 午夜精品久久久久久久久| 亚洲影视在线| 欧美一区二区在线播放| 久久都是精品| 久久视频在线视频| 欧美a一区二区| 免费日本视频一区| 亚洲国产精品女人久久久| 欧美激情视频给我| 亚洲精品久久视频| 国产精品99久久久久久久久| 亚洲一区二区三区高清| 欧美影院在线| 欧美电影免费观看高清完整版| 欧美激情成人在线视频| 欧美日韩在线大尺度| 国产精品入口尤物| 国产日韩精品一区观看 | 欧美人在线视频| 欧美日韩在线视频一区| 国产精品久久久亚洲一区| 国产欧美日韩三级| 激情校园亚洲| 夜夜嗨av一区二区三区四区| 亚洲女ⅴideoshd黑人| 久久美女性网| 亚洲国产日日夜夜| 亚洲影院在线| 免费久久精品视频| 国产精品久久久99| 1024成人网色www| 亚洲一区二区三区乱码aⅴ| 久久成人人人人精品欧| 欧美激情按摩在线| 亚洲欧美日本国产有色| 美女主播视频一区| 国产精品久久久久久久免费软件| 国精品一区二区三区| 99riav国产精品| 久久久久一本一区二区青青蜜月| 欧美国产日韩一区| 亚洲天堂激情| 欧美成人国产va精品日本一级| 国产噜噜噜噜噜久久久久久久久| 亚洲高清视频一区| 欧美专区在线| 日韩视频一区二区三区在线播放| 久久精品av麻豆的观看方式| 欧美天天影院| 亚洲日本成人网| 久久女同精品一区二区| 亚洲午夜激情| 欧美另类变人与禽xxxxx| 精品成人国产在线观看男人呻吟|