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

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

DFS學習筆記

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

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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 乐东| 灵丘县| 永昌县| 渭源县| 陆河县| 南宫市| 广安市| 三门县| 陆良县| 桃园县| 柏乡县| 澄江县| 隆林| 嵊州市| 漳浦县| 绿春县| 东莞市| 林州市| 曲周县| 长垣县| 故城县| 麻城市| 甘南县| 漠河县| 大竹县| 正蓝旗| 团风县| 禹州市| 乳源| 石景山区| 广饶县| 通山县| 大丰市| 左云县| 拉孜县| 山东省| 富民县| 安泽县| 南平市| 静安区| 万安县|