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

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年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

統計

常用鏈接

留言簿(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>
            午夜宅男欧美| 免费成人av| 亚洲欧洲av一区二区三区久久| 久久只有精品| 小嫩嫩精品导航| 国产精品黄视频| 在线视频精品一区| 亚洲高清免费| 久久国产精品久久精品国产| 国产精品第一区| 亚洲香蕉网站| 99成人在线| 欧美日韩一卡二卡| 一本色道88久久加勒比精品| 欧美激情欧美激情在线五月| 老妇喷水一区二区三区| 在线观看亚洲精品| 免费在线欧美黄色| 久久一区二区精品| 亚洲国产视频a| 欧美激情中文字幕在线| 欧美成人精品福利| 日韩午夜在线观看视频| 亚洲精品偷拍| 欧美日韩高清一区| 亚洲欧美国产日韩中文字幕 | 久久成人一区二区| 国产日韩欧美电影在线观看| 国产精品久久久一区二区三区| 亚洲一二三区视频在线观看| 夜夜嗨av一区二区三区网站四季av| 欧美日韩精品久久久| 亚洲一区二区欧美| 亚洲综合第一页| 黄色精品一区| 欧美激情按摩在线| 欧美性理论片在线观看片免费| 午夜激情综合网| 久久免费国产| 99riav国产精品| 亚洲免费影院| 亚洲二区视频在线| 99精品视频免费| 国内精品**久久毛片app| 欧美激情在线| 国产精品日韩精品| 免费国产自线拍一欧美视频| 欧美日本乱大交xxxxx| 午夜精品久久久久久久久久久久| 久久精品中文| 亚洲一区欧美二区| 久久五月天婷婷| 亚洲欧美综合| 欧美国产日韩一区二区| 欧美一区免费视频| 欧美激情va永久在线播放| 久久9热精品视频| 欧美大片第1页| 久久久水蜜桃| 国产精品久久久久久亚洲调教| 欧美v日韩v国产v| 国产精品国产三级国产普通话99 | 另类图片国产| 欧美日韩国产一区二区三区地区| 久久精品久久99精品久久| 欧美高清成人| 老司机免费视频久久| 国产精品欧美精品| 亚洲免费观看高清在线观看| 一区精品久久| 亚洲欧美日韩人成在线播放| 一本色道88久久加勒比精品 | 欧美一区二区在线观看| 一本色道久久综合亚洲精品婷婷 | 99国产精品99久久久久久| 在线不卡视频| 亚洲欧美日韩精品综合在线观看 | 一区二区av在线| 亚洲黄色免费电影| 久久久精品动漫| 亚洲精品美女在线观看| 久久久www成人免费毛片麻豆| 亚洲欧美成人精品| 欧美精品国产| 欧美激情一区二区三级高清视频 | 在线亚洲高清视频| 免费中文字幕日韩欧美| 老司机免费视频一区二区三区| 国产三级欧美三级| 亚洲一区中文| 亚洲欧美一级二级三级| 欧美视频不卡| 99re亚洲国产精品| 一级日韩一区在线观看| 欧美精品一区二区三| 亚洲国产精品va在线看黑人| 亚洲国产精品99久久久久久久久| 久久精品99国产精品日本 | 亚洲麻豆视频| 99精品视频一区二区三区| 欧美国产日韩a欧美在线观看| 欧美激情一区在线| 亚洲免费电影在线观看| 欧美理论电影网| 99在线精品观看| 亚洲一区尤物| 国产精品自拍小视频| 欧美影片第一页| 美日韩在线观看| 91久久精品www人人做人人爽| 免费在线亚洲欧美| 99热免费精品| 久久精品国产99国产精品澳门| 国产香蕉97碰碰久久人人| 久久九九国产精品| 亚洲国产高清一区| 亚洲午夜精品一区二区三区他趣| 国产精品欧美日韩一区二区| 午夜一级久久| 亚洲国产精品va在看黑人| 亚洲一区激情| 国产一区二区三区精品久久久| 浪潮色综合久久天堂| 9色精品在线| 久久久国产精品一区| 亚洲国产精品国自产拍av秋霞| 欧美激情亚洲激情| 亚洲免费影视| 亚洲国产欧美一区二区三区丁香婷| 中文日韩在线视频| 国内精品久久久久影院优 | 亚洲国产精品第一区二区三区 | 欧美一区二区视频在线| 狠狠色狠狠色综合日日五| 欧美+日本+国产+在线a∨观看| 夜夜精品视频| 欧美777四色影视在线| 亚洲视频狠狠| 影院欧美亚洲| 国产精品久久久久一区二区三区共| 久久久久久久综合狠狠综合| 亚洲九九精品| 麻豆国产精品一区二区三区| 中日韩午夜理伦电影免费| 在线观看欧美精品| 影音先锋亚洲一区| 久久久久国色av免费看影院| 一区二区三区蜜桃网| 欧美福利在线观看| 欧美在线免费| 在线视频亚洲一区| 亚洲国产一区二区精品专区| 国产日韩高清一区二区三区在线| 欧美va亚洲va国产综合| 午夜精品一区二区三区四区 | 欧美一区二区三区免费观看视频| 在线观看日韩一区| 国产伦精品一区二区三区照片91 | 欧美视频福利| 免费亚洲电影| 久久激情久久| 性xx色xx综合久久久xx| 亚洲视频在线观看视频| 日韩视频一区二区在线观看| 亚洲国产精品精华液2区45| 久久夜色精品一区| 欧美一区二区三区视频在线 | 亚洲国产精品一区| 久久综合久久综合久久| 欧美诱惑福利视频| 亚洲欧美日韩国产一区二区| 一本久道久久综合中文字幕| 亚洲高清不卡在线| 在线不卡a资源高清| 国外精品视频| 一区二区视频免费完整版观看| 国产综合久久| 黄色成人av网| 今天的高清视频免费播放成人| 国产伦精品一区二区三区视频黑人| 欧美午夜性色大片在线观看| 国产精品sm| 国产精品一二三| 国产日韩精品视频一区| 国产婷婷精品| 国语精品中文字幕| 在线观看的日韩av| 亚洲人成在线播放| 日韩一级欧洲| 亚洲自拍三区| 久久九九精品| 美女脱光内衣内裤视频久久影院| 久久综合99re88久久爱| 狂野欧美激情性xxxx| 欧美国产极速在线| 亚洲精品久久| 亚洲综合二区| 久久国产婷婷国产香蕉| 久久亚洲二区| 欧美日韩国产综合视频在线观看中文|