国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

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

DFS學習筆記

2019-11-09 19:37:39
字體:
來源:轉載
供稿:網友

DFS(深度優先搜索) 比較暴力功利,大意是將某一個狀態開始不斷轉移到下一個狀態,直到不能轉移,然后退回到前一個分枝的另一個下一個狀態以此類推,直到找到最終的解

心得:找到終止條件和分支的條件

例題:從N個數中找到其中的幾個數使他們的和恰好為K

#include<iostream>#define maxn 10000using namespace std;int a[maxn];int n,k;bool dfs(int i,int sum){ if(i==n) return sum==k; //終止條件 if(dfs(i+1,sum)) return true; //分支條件 else if(dfs(i+1,sum+a[i])) return true; return false;}int main(){ cin>>n; for(int i=0;i<n;i++) cin>>a[i]; cin>>k; if(dfs(0,0)) cout<<"yes"<<endl; else cout<<"no"<<endl; return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 寻甸| 怀来县| 新平| 南部县| 建德市| 稷山县| 专栏| 北碚区| 遵义市| 河曲县| 定襄县| 斗六市| 互助| 客服| 巴中市| 芜湖县| 特克斯县| 龙胜| 九龙县| 托里县| 松滋市| 阳曲县| 通海县| 定边县| 巴林右旗| 永德县| 日喀则市| 海伦市| 勃利县| 沁阳市| 河源市| 墨竹工卡县| 延庆县| 陵水| 萨嘎县| 青浦区| 韩城市| 奎屯市| 绥德县| 团风县| 绥德县|