亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

HDOJ(HDU).1016 Prime Ring Problem (DFS)

2019-11-11 06:13:59
字體:
來源:轉載
供稿:網友

HDOJ(HDU).1016 PRime Ring Problem (DFS) [從零開始DFS(3)]

從零開始DFS HDOJ.1342 Lotto [從零開始DFS(0)] — DFS思想與框架/雙重DFS HDOJ.1010 Tempter of the Bone [從零開始DFS(1)] —DFS四向搜索/奇偶剪枝 HDOJ(HDU).1015 Safecracker [從零開始DFS(2)] —DFS四向搜索變種 HDOJ(HDU).1016 Prime Ring Problem (DFS) [從零開始DFS(3)] —小結:做DFS題目的關注點 HDOJ(HDU).1035 Robot Motion [從零開始DFS(4)]—DFS題目練習 HDOJ(HDU).1241 Oil Deposits(DFS) [從零開始DFS(5)] —DFS八向搜索/雙重for循環遍歷 HDOJ(HDU).1258 Sum It Up (DFS) [從零開始DFS(6)] —DFS雙重搜索/去重技巧 HDOJ(HDU).1045 Fire Net [從零開始DFS(7)]—DFS練習/check函數的思想

題意分析

給出數字n,要求將1-n的數字填成素數環,即相鄰2個數字的和為素數,按字典序依次輸出所有可能的組合。并且題目說過所有的組合開頭均為1。

哎呀這題太熟悉了,又是填數字的題目,似曾相識的感覺。 討論過的填數字的題目,傳送門:

HDOJ(HDU).1342 Lotto [從零開始DFS(0)] HDOJ(HDU).1015 Safecracker [從零開始DFS(2)]

如果獨立完成了幾道dfs的題目,就會發現:其實dfs只是工具,真正考察思維的,是什么時候進行dfs,怎樣進行dfs

1.什么時候進行dfs:即遞歸邊界。滿足何種情況就不進行搜索了,或者何種情況進行一個輸出,亦或是利用條件判斷去掉重復的情況。 2.怎樣進行dfs:是二重搜索(HDOJ.1342),還是四向搜索(HDOJ.1010),還是在數組中找遍所有的元素(HDOJ.1015)。也許以后還有八向搜索,全部搜索等等方式。

不難發現本題要求的是,兩個相鄰的數字和為素數,那么也就是在每次搜索的時候,都判斷一下前2個數字的和是否為素數,若是的話繼續進行搜索,否則終止。

需要注意的是,最后還需要判斷一下,最后一個數字和第一個數字的和是否為素數,因為題目的要求是素數環嘛。否則會出現多解。

為了方便判斷素數,最好在初始化的時候進行素數篩。規模在50即可(n上限是19,最大就是19+18=37)。

上代碼。

代碼總覽

/* HDOJ.1016 Author:pengwill Date:2017-2-5*/#include <iostream>#include <cstdio>#include <cstring>#include <cmath>#include <algorithm>using namespace std;bool visit[21],prime[51];int b[21],n;void init(){ // prime 0 & not prime 1 for(int i = 2; i<=sqrt(50) ;++ i) if(prime[i] == 0){ for(int j = 2;i*j<=50;++j) prime[i*j] = 1; } prime[1] = 0; visit[1] = true;b[1] = 1;}bool check(int depth){ if(depth == n+1)//對于最后要判斷首位數字的和是否為素數 if(prime[b[1]+b[depth-1]] == 0 && prime[b[depth-2]+b[depth-1]] == 0) return true; else return false; else if(prime[b[depth-2]+b[depth-1]] == 0) return true;//若不是最后就直接判斷前2個即可 else return false;}void print(){ for(int i = 1;i<=n; ++i) if(i == 1) printf("%d",b[i]); else printf(" %d",b[i]); printf("/n");}void dfs(int depth){ if(false == check(depth)) return; if(depth == n+1){ //輸出 print(); return; } for(int i = 2; i<=n ;++i){ if(!visit[i]){ visit[i] = 1; b[depth] = i; dfs(depth+1); visit[i] = 0; } }}int main(){ int t = 1; init(); while(scanf("%d",&n) != EOF){ printf("Case %d:/n",t++); if(1==n) printf("1/n"); else dfs(2);//第一位是1,故從深度為2開始dfs printf("/n"); } return 0;}

對n為1的時候進行特判。 init函數打50規模的素數表,然后把1置為訪問過。若n不為1,對深度為2進行dfs。 每次在遞歸調用dfs之前,首先檢查一下前邊2個數的和(depth-1和depth-2)是否為素數。(因為b[0]為0,當depth為2的時候也可以直接調用check函數,不用特判)。需要注意的是,當depth為n+1的時候,check需要檢查兩項內容:一是剛才說的前兩個數的和是否為素數,二是最后一個數和第一個數的和是否為素數。這樣就能保證是素數環了。

本題還有一個坑點,就是輸出格式。輸出可能組合的時候注意是每個數字之間有一個空格,也就是在行末尾只有一個換行符。題目還說了在每種case之后輸出個空行,也就是說不是每組數據之間(原文表述是 Print a blank line after each case. 是after,不是between)。 所以最后還是有一個空行的。

此題不難,dfs活學活用才是王道?。。?/p>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品视频久久久久久久| 伦伦影院午夜日韩欧美限制| 亚洲黄色成人网| 亚洲自拍小视频| 欧美日韩国产一区中文午夜| 在线播放日韩专区| 日韩av片电影专区| 在线观看国产欧美| 精品一区二区三区三区| 欧美激情videoshd| 欧美极品少妇xxxxⅹ裸体艺术| 久操成人在线视频| 亚洲xxxxx电影| 国产日韩综合一区二区性色av| 欧美日韩中文在线| 日韩成人在线免费观看| 久久精品视频99| 日韩欧美高清在线视频| 国产日韩中文字幕在线| 欧美成人自拍视频| 69久久夜色精品国产69| 最近的2019中文字幕免费一页| 国产精品自拍网| 欧美亚洲另类制服自拍| 国产在线a不卡| 亚洲色图国产精品| 国产成人啪精品视频免费网| 欧美在线视频免费| 国产精品久久久久久久久久新婚| 国产精品第二页| 亚洲最大在线视频| 欧美国产日韩在线| 欧美怡红院视频一区二区三区| 欧美国产日韩xxxxx| 亚洲va欧美va国产综合久久| 欧洲美女免费图片一区| 国产97色在线| 爱福利视频一区| 日韩毛片中文字幕| 亚洲娇小xxxx欧美娇小| 国产成人精品午夜| 欧美激情精品久久久久| 亚洲欧洲偷拍精品| 日本国产高清不卡| 国产精品视频播放| 欧美亚洲伦理www| 国产欧美日韩精品专区| 中文字幕欧美日韩在线| …久久精品99久久香蕉国产| 国产日韩欧美夫妻视频在线观看| 日产日韩在线亚洲欧美| 91精品久久久久久久久中文字幕| 亚洲欧美中文日韩在线| 亚洲欧洲第一视频| 亚洲性线免费观看视频成熟| 亚洲欧美国产高清va在线播| 亚洲女人被黑人巨大进入al| 国产亚洲人成网站在线观看| 久久6免费高清热精品| 亚洲国产成人精品女人久久久| 亚洲精品福利在线观看| 性金发美女69hd大尺寸| 亚洲女人天堂成人av在线| 欧美性理论片在线观看片免费| 一本色道久久88亚洲综合88| 97视频免费在线观看| 久久成人av网站| 亚洲成人中文字幕| 久久综合网hezyo| 欧美成人sm免费视频| 97不卡在线视频| 欧美日韩免费区域视频在线观看| 日韩在线视频观看正片免费网站| 国产一区二区在线免费视频| 国产日韩av高清| 久久久久久91| 亚洲天堂av综合网| 国产一级揄自揄精品视频| 国产成人精品午夜| 成人综合国产精品| 欧美特级www| 国产精品一区久久久| 亚洲精品99999| 国产精品久久久久久久美男| 欧美精品免费在线观看| 欧美黑人xxxⅹ高潮交| 欧美午夜影院在线视频| 色偷偷91综合久久噜噜| 亚洲视屏在线播放| 久久久久久欧美| 日韩av123| 国产成人激情视频| 欧美亚洲一级片| 久久精品99无色码中文字幕| 欧美午夜精品在线| 91精品在线观看视频| 欧美一区二区三区免费视| 国产91精品久| 国产在线精品自拍| 国内精品免费午夜毛片| 日韩av免费看网站| 久久九九热免费视频| 亚洲精品国产综合久久| 中文字幕亚洲自拍| 亚洲第一区在线| 91久久精品久久国产性色也91| 久久视频在线看| 美女福利视频一区| 日韩中文在线中文网在线观看| 精品国产区一区二区三区在线观看| 久久精品影视伊人网| 中文字幕亚洲综合久久| 亚洲资源在线看| 亚洲偷熟乱区亚洲香蕉av| 国产美女主播一区| 日韩激情av在线免费观看| 日本午夜精品理论片a级appf发布| 欧美日韩国产精品一区二区三区四区| 亚洲a区在线视频| 97超级碰碰碰| 亚洲国产日韩欧美在线动漫| 精品久久久久久久中文字幕| 亚洲精品720p| 超薄丝袜一区二区| 中文字幕国产日韩| 亚洲bt欧美bt日本bt| 欧美在线视频观看免费网站| 午夜精品久久久久久久99黑人| 久久久电影免费观看完整版| 在线播放日韩精品| 亚洲成色999久久网站| 91色琪琪电影亚洲精品久久| 91国产美女视频| 国产精品一区二区av影院萌芽| 日韩成人黄色av| 国产一区二区在线播放| 精品亚洲夜色av98在线观看| 国产美女91呻吟求| 伊人久久免费视频| 国产精品网站大全| 欧美黑人极品猛少妇色xxxxx| 亚洲精品福利免费在线观看| 欧美裸体xxxx极品少妇| 亚洲iv一区二区三区| 亚洲国产成人精品久久| 中文字幕国产日韩| 国产精品激情av在线播放| 成人国产亚洲精品a区天堂华泰| 国产中文日韩欧美| 欧美日韩中文在线观看| 俺去亚洲欧洲欧美日韩| 一本大道久久加勒比香蕉| 亚洲国产91精品在线观看| 日韩av一卡二卡| 欧美成人激情在线| 成人欧美在线观看| 日韩av免费一区| 欧美另类xxx| 亚洲精品一区二区久| 国产精品高潮在线| 欧美日韩国产成人在线| 欧美另类极品videosbestfree| 精品电影在线观看| 精品视频偷偷看在线观看|