日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

非常可乐——BFS

發布時間:2023/11/30 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 非常可乐——BFS 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

【題目描述】
大家一定覺的運動以后喝可樂是一件很愜意的事情,但是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

【題目分析】
看到最少的次數就應該想到應該是BFS,需要注意的是如何進行BFS以及如何標記已經訪問過的狀態。對于這道題,我們可以用一個二維數組保存狀態,用兩個循環來表示倒的過程,進行枚舉。注意杯子里面沒有水是不能往出倒的,然后還需要進行分類討論
【AC代碼】

#include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #include<cmath> #include<climits> #include<string> #include<queue> using namespace std;const int MAXN=105; int s,n,m,half; int a[3]; struct node {int tmp[3];int step; }t,p; int vis[MAXN][MAXN][MAXN];void BFS() {a[0]=s; a[1]=n; a[2]=m;queue<node> q;memset(vis,0,sizeof(vis));p.tmp[0]=s; p.tmp[1]=0; p.tmp[2]=0;p.step=0;vis[s][0][0]=1;q.push(p);while(!q.empty()){p=q.front(); q.pop();for(int i=0;i<3;i++){if(p.tmp[i]>0){for(int j=0;j<3;j++){t=p;if(i==j) continue;if(t.tmp[i]>=a[j]-t.tmp[j]){t.tmp[i]=t.tmp[i]-a[j]+t.tmp[j];t.tmp[j]=a[j];}else{t.tmp[j]+=t.tmp[i];t.tmp[i]=0;}if(!vis[t.tmp[0]][t.tmp[1]][t.tmp[2]]){vis[t.tmp[0]][t.tmp[1]][t.tmp[2]]=1;t.step++;if(t.tmp[0]==half&&t.tmp[1]==half || t.tmp[0]==half&&t.tmp[2]==half || t.tmp[1]==half&&t.tmp[2]==half){printf("%d\n",t.step);return;}q.push(t);}}}}}printf("NO\n"); }int main() {while(~scanf("%d%d%d",&s,&n,&m)&&(n || m || s)){if(s%2)//如果原本杯子里的水不是2的倍數肯定是無法分成相等的兩部分的printf("NO\n");else{half=s/2;BFS();}}return 0; }

總結

以上是生活随笔為你收集整理的非常可乐——BFS的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产 欧美 日本 | 精品麻豆 | 999精品一区| 午夜视频网站在线观看 | 亚洲中字在线 | 亚洲综合日韩精品欧美综合区 | 动漫一区二区三区 | 国产成人av一区 | 日本强好片久久久久久aaa | 免费看黄在线 | 俄罗斯精品一区二区三区 | 91狠狠操| 超91在线| 天天cao在线 | 69式视频| av毛片网 | 国产福利免费看 | 一级黄色免费看 | 123超碰| 2021狠狠操 | 高跟91白丝 | 午夜影院一区二区 | 国产大尺度视频 | 日韩精品一区二区三区无码专区 | 三级福利片 | 国产激情啪啪 | 日韩高清二区 | 黄色综合网站 | jlzzjizz在线播放观看 | 五月天欧美 | 国产福利免费观看 | 国产视频手机在线观看 | 中文字幕av一区二区三区谷原希美 | 国产天天操 | 精品无码国产污污污在线观看 | 夫妻精品 | av片毛片| 日韩av福利 | 草逼国产 | 久久性生活片 | a级免费网站 | 亚州一区二区 | 最新国产网址 | 福利一区二区在线观看 | 碧蓝之海动漫在线观看免费高清 | 天天干人人 | 日韩av网站在线观看 | 中国zzji女人高潮免费 | 欧洲国产精品 | 日韩精品久久久久久久电影99爱 | jizzjizz亚洲 | 在线播放黄色av | 亚洲v国产v| 国产精品欧美一区喷水 | 亚洲自拍激情 | 很黄很污的视频 | 免费激情av | 激情戏网站 | 亚洲男人的天堂网站 | 国产性色视频 | 岛国av动作片 | 国产一区二区视频在线免费观看 | 久久6| 又大又硬又爽免费视频 | 宅男午夜影院 | 免费的一级黄色片 | 999av视频| 男人操女人的视频 | 激情片 | 午夜影院黄 | 黑丝av在线 | 国产精品激情偷乱一区二区∴ | 亚洲精品国产一区 | 蜜桃传媒一区二区亚洲 | 亚洲欧美激情精品一区二区 | 欧美精品v国产精品v日韩精品 | 无码精品人妻一区二区三区影院 | 精品久久a | 国产精品三级久久久久久电影 | 国产精品免费观看视频 | 成年人免费看的视频 | 99视频这里有精品 | 一本一道人人妻人人妻αv 九一在线视频 | av青娱乐 | 俄罗斯av在线 | 老鸭窝一区二区 | 无码人妻黑人中文字幕 | 精品国产乱码久久久久久免费 | 综合激情伊人 | 噼里啪啦免费看 | 久久久久国产精品区片区无码 | 红桃视频隐藏入口 | 肉丝超薄少妇一区二区三区 | 日本精品在线 | 国产成人在线观看免费网站 | 男女高h视频 | 国产精品一区二区精品 | 一区欧美 | 国产911视频 |