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

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>
            久久久噜噜噜久久中文字幕色伊伊| 久久国产精品72免费观看| 欧美三级网址| 欧美一区二区三区在线视频| 新67194成人永久网站| 亚洲精品一区在线观看| 久久亚洲精选| 久热精品视频在线| 噜噜噜躁狠狠躁狠狠精品视频| 美女国产一区| 欧美日韩在线播放三区| 国产精品乱码一区二区三区| 国产日韩综合| 亚洲人体影院| 午夜欧美大尺度福利影院在线看| 久久爱另类一区二区小说| 蜜桃av一区二区| 一区二区欧美在线观看| 久久九九国产精品| 欧美午夜精品久久久久久超碰| 国产亚洲美州欧州综合国| 亚洲精品欧洲| 性久久久久久久| 欧美激情91| 亚洲视频一区在线观看| 久久九九国产| 国产精品免费在线| 亚洲精品一二三| 久久精品男女| 亚洲最新合集| 欧美美女bbbb| 在线观看视频免费一区二区三区| 亚洲午夜精品视频| 亚洲第一精品福利| 亚洲一区在线免费| 欧美日韩国产成人在线91| 国内精品一区二区| 欧美亚洲色图校园春色| 99精品热6080yy久久 | 亚洲麻豆av| 久久成年人视频| 99在线精品视频| 美国三级日本三级久久99| 国产日本欧美一区二区三区在线| 99视频+国产日韩欧美| 欧美a级一区| 久久免费视频观看| 国产一区二区三区四区三区四| 亚洲午夜羞羞片| 亚洲日本在线观看| 欧美成人免费一级人片100| 国外成人网址| 久久在线观看视频| 久久精品视频网| 国模精品一区二区三区色天香| 亚洲视频在线免费观看| 日韩天天综合| 欧美性片在线观看| 亚洲性av在线| 一区二区三区高清视频在线观看 | 午夜欧美大尺度福利影院在线看| 久久久五月婷婷| 国产在线视频欧美| 久久久久久久久久久久久9999| 亚洲欧美在线高清| 国产伦精品一区二区三区免费迷| 亚洲欧美日韩一区| 亚洲自拍电影| 国产综合久久久久久| 蜜臀va亚洲va欧美va天堂| 久久久精品一区| 亚洲精品免费网站| 一区二区三区高清在线 | 久久久久久亚洲综合影院红桃 | 亚洲午夜三级在线| 亚洲与欧洲av电影| 国产一区二区精品久久99| 久久噜噜亚洲综合| 蜜桃av一区| 亚洲在线网站| 久久久精品一品道一区| 亚洲毛片在线看| 亚洲一区二区视频在线| 国产亚洲欧美中文| 亚洲国产高清一区| 国产精品人人做人人爽| 久久女同互慰一区二区三区| 欧美成人精品在线| 午夜精品视频| 免费成人av在线| 亚洲欧美综合精品久久成人| 香蕉尹人综合在线观看| 亚洲激情国产| 香蕉久久a毛片| 亚洲精品自在在线观看| 亚洲一区二区三区涩| 亚洲国产成人tv| 亚洲一区二区成人在线观看| 在线欧美三区| 亚洲女人小视频在线观看| 亚洲第一黄网| 午夜日韩激情| 亚洲午夜91| 美女图片一区二区| 久久福利毛片| 欧美日在线观看| 欧美成人午夜77777| 国产精品一区二区久久精品| 亚洲电影第三页| 国产亚洲精品久久久久动| 亚洲蜜桃精久久久久久久| 激情欧美一区二区三区在线观看 | 久久国产精品亚洲va麻豆| 亚洲麻豆视频| 久久久精品日韩| 男男成人高潮片免费网站| 亚洲韩国一区二区三区| 亚洲无线观看| 狼人天天伊人久久| 午夜久久美女| 欧美日韩ab| 亚洲国产精品一区二区第一页 | 国产精品久久亚洲7777| 免费观看日韩| 国产一区美女| 香蕉尹人综合在线观看| 午夜一级久久| 国产精品久久久久久久久借妻| 亚洲人成在线观看网站高清| 亚洲第一中文字幕| 久久国产99| 免费短视频成人日韩| 国产一区二区三区直播精品电影 | 亚洲成人资源| 影音国产精品| 久久久在线视频| 久久影院亚洲| 亚洲大片精品永久免费| 久久资源在线| 亚洲国产精品欧美一二99| 亚洲高清视频一区二区| 久久亚洲综合色| 欧美国产三级| 一本色道久久88综合亚洲精品ⅰ| 欧美黄色一区| 一区二区精品在线观看| 亚洲欧美视频一区二区三区| 国产精品久久久久久模特| 亚洲欧美中文在线视频| 久久久综合香蕉尹人综合网| 亚洲福利免费| 欧美日韩国产精品一区| 国产精品99久久久久久白浆小说| 亚洲一区黄色| 国际精品欧美精品| 欧美大胆成人| 亚洲性图久久| 欧美h视频在线| 亚洲视频在线一区| 国产综合色产在线精品| 欧美va天堂在线| 亚洲五月婷婷| 欧美成人自拍| 亚洲一区二区三区四区五区午夜| 国产精品永久免费视频| 久久尤物视频| 亚洲天堂男人| 欧美r片在线| 亚洲永久免费视频| 精品成人一区二区三区四区| 欧美成人r级一区二区三区| 一区二区三区高清在线观看| 久久综合导航| 欧美成人午夜77777| 亚洲人人精品| 看片网站欧美日韩| 亚洲欧洲日产国产综合网| 午夜久久久久久| 黄网动漫久久久| 欧美涩涩视频| 久久综合中文色婷婷| 亚洲一区久久| 亚洲片在线资源| 久久只精品国产| 欧美一区二区在线免费观看| 亚洲肉体裸体xxxx137| 国产欧美二区| 欧美日韩中文另类| 免费91麻豆精品国产自产在线观看| 亚洲视频精选在线| 亚洲精品国精品久久99热一| 久久精品一区二区三区不卡| 亚洲午夜激情网站| 一本色道久久88综合亚洲精品ⅰ | 黄色亚洲在线| 国产精品一区一区| 国产精品白丝av嫩草影院| 欧美a级片网| 久久亚洲二区| 久久久久国色av免费看影院|