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

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

DFS學習筆記

2019-11-10 17:19:50
字體:
來源:轉載
供稿:網友

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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 湘西| 霍林郭勒市| 福泉市| 当阳市| 蒙山县| 如皋市| 筠连县| 镇江市| 清苑县| 嵩明县| 台南县| 阳春市| 岑巩县| 都匀市| 浦县| 唐河县| 宁津县| 河池市| 东港市| 福建省| 集贤县| 和田县| 华宁县| 延津县| 吐鲁番市| 佛山市| 广平县| 化州市| 易门县| 布尔津县| 奎屯市| 泸定县| 依兰县| 汽车| 北票市| 敦化市| 桃园县| 北川| 远安县| 平山县| 宝应县|