HDU-1495 非常可乐(BFS)
广搜的灵活应用题:
非常可乐
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 3633 Accepted Submission(s): 1514
Problem Description
大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为。因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶可乐,而且一定要喝的和seeyou一样多。但seeyou的手中只有两个杯子,它们的容量分别是N 毫升和M 毫升 可乐的体积为S (S<101)毫升 (正好装满一瓶) ,它们三个之间可以相互倒可乐 (都是没有刻度的,且 S==N+M,101>S>0,N>0,M>0) 。聪明的ACMER你们说他们能平分吗?如果能请输出倒可乐的最少的次数,如果不能输出"NO"。
Input
三个整数 : S 可乐的体积 , N 和 M是两个杯子的容量,以"0 0 0"结束。
Output
如果能平分的话请输出最少要倒的次数,否则输出"NO"。
Sample Input
7 4 3
4 1 3
0 0 0
Sample Output
NO 3
1 //一共6种情况;all->big,all->small,big->small,big->all,small->all,small->big进行bfs搜索,如果未被搜到过, 2 //就入队列,如果出现两个瓶子里水相同就返回输出。(总水量为奇数时无解) 3 #include<stdio.h> 4 #include<string.h> 5 #include<queue> 6 using namespace std; 7 struct node 8 { 9 int s,n,m; 10 int step; 11 }; 12 int hash[101][101][101]; 13 int s,n,m; 14 15 int BFS() 16 { 17 queue<node>q; 18 node cur,next; 19 cur.s=s; 20 cur.n=0; 21 cur.m=0; 22 cur.step=0; 23 hash[cur.s][cur.n][cur.m]=1; 24 q.push(cur); 25 while(!q.empty()) 26 { 27 cur=q.front(); 28 q.pop(); 29 if((cur.n==0 && cur.m==cur.s)||(cur.m==0 && cur.n==cur.s)||( cur.s==0 && cur.n==cur.m)) return cur.step; 30 if(cur.n!=0) 31 { 32 if(cur.n>s-cur.s) 33 { 34 next.n=cur.n-(s-cur.s); 35 next.s=s; 36 next.m=cur.m; 37 if(hash[next.s][next.n][next.m]==0) 38 { 39 next.step=cur.step+1; 40 q.push(next); 41 hash[next.s][next.n][next.m]=1; 42 } 43 } 44 else 45 { 46 next.n=0; 47 next.s=cur.s+cur.n; 48 next.m=cur.m; 49 if(hash[next.s][next.n][next.m]==0) 50 { 51 next.step=cur.step+1; 52 q.push(next); 53 hash[next.s][next.n][next.m]=1; 54 } 55 } 56 if(cur.n>m-cur.m) 57 { 58 next.n=cur.n-(m-cur.m); 59 next.m=m; 60 next.s=cur.s; 61 if(hash[next.s][next.n][next.m]==0) 62 { 63 next.step=cur.step+1; 64 q.push(next); 65 hash[next.s][next.n][next.m]=1; 66 } 67 } 68 else 69 { 70 next.n=0; 71 next.m=cur.m+cur.n; 72 next.s=cur.s; 73 if(hash[next.s][next.n][next.m]==0) 74 { 75 next.step=cur.step+1; 76 q.push(next); 77 hash[next.s][next.n][next.m]=1; 78 } 79 } 80 } 81 82 if(cur.m) 83 { 84 if(cur.m>s-cur.s) 85 { 86 next.m=cur.n-(s-cur.s); 87 next.s=s; 88 next.n=cur.n; 89 if(hash[next.s][next.n][next.m]==0) 90 { 91 next.step=cur.step+1; 92 q.push(next); 93 hash[next.s][next.n][next.m]=1; 94 } 95 } 96 else 97 { 98 next.m=0; 99 next.s=cur.s+cur.m; 100 next.n=cur.n; 101 if(hash[next.s][next.n][next.m]==0) 102 { 103 next.step=cur.step+1; 104 q.push(next); 105 hash[next.s][next.n][next.m]=1; 106 } 107 } 108 if(cur.m>n-cur.n) 109 { 110 next.m=cur.m-(n-cur.n); 111 next.n=n; 112 next.s=cur.s; 113 if(hash[next.s][next.n][next.m]==0) 114 { 115 next.step=cur.step+1; 116 q.push(next); 117 hash[next.s][next.n][next.m]=1; 118 } 119 } 120 else 121 { 122 next.m=0; 123 next.n=cur.m+cur.n; 124 next.s=cur.s; 125 if(hash[next.s][next.n][next.m]==0) 126 { 127 next.step=cur.step+1; 128 q.push(next); 129 hash[next.s][next.n][next.m]=1; 130 } 131 } 132 } 133 134 if(cur.s) 135 { 136 if(cur.s>n-cur.n) 137 { 138 next.s=cur.s-(n-cur.n); 139 next.n=n; 140 next.m=cur.m; 141 if(hash[next.s][next.n][next.m]==0) 142 { 143 next.step=cur.step+1; 144 q.push(next); 145 hash[next.s][next.n][next.m]=1; 146 } 147 } 148 else 149 { 150 next.s=0; 151 next.n=cur.s+cur.n; 152 next.m=cur.m; 153 if(hash[next.s][next.n][next.m]==0) 154 { 155 next.step=cur.step+1; 156 q.push(next); 157 hash[next.s][next.n][next.m]=1; 158 } 159 } 160 if(cur.s>m-cur.m) 161 { 162 next.s=cur.s-(m-cur.m); 163 next.m=m; 164 next.n=cur.n; 165 if(hash[next.s][next.n][next.m]==0) 166 { 167 next.step=cur.step+1; 168 q.push(next); 169 hash[next.s][next.n][next.m]=1; 170 } 171 } 172 else 173 { 174 next.s=0; 175 next.m=cur.m+cur.s; 176 next.n=cur.n; 177 if(hash[next.s][next.n][next.m]==0) 178 { 179 next.step=cur.step+1; 180 q.push(next); 181 hash[next.s][next.n][next.m]=1; 182 } 183 } 184 } 185 } 186 187 return 0; 188 } 189 int main() 190 { 191 int ans; 192 while(scanf("%d%d%d",&s,&n,&m),s||n||m) 193 { 194 memset(hash,0,sizeof(hash)); 195 196 if(s%2) {printf("NO\n");continue;} 197 198 ans=BFS(); 199 if(ans) printf("%d\n",ans); 200 else printf("NO\n"); 201 } 202 return 0; 203 }