当前位置: 首页 > wzjs >正文

wap手机网站制作网站公司网站建设

wap手机网站制作,网站公司网站建设,店面设计费计入什么科目,为什么电子网站开发DFS是一种暴力的搜索,其核心思想是遍历所有方案,一条路走到黑再进行回溯。存储时只需要存储路径。 例1:按字典序输出1-n的全排列。 这就要求我们做到前面已经用过的数字不再出现,因此我们需要一个state数组来去重并且在回溯时恢…

DFS是一种暴力的搜索,其核心思想是遍历所有方案,一条路走到黑再进行回溯。存储时只需要存储路径。

例1:按字典序输出1-n的全排列。

这就要求我们做到前面已经用过的数字不再出现,因此我们需要一个state数组来去重并且在回溯时恢复现场。

int path[N];//保存序列
int state[N];//数字是否被用过
int n;
void dfs(int u)//u代表当前的层数
{if(u > n)//数字填完了,输出{for(int i = 1; i <= n; i++)//输出方案cout << path[i] << " ";cout << endl;return ;}for(int i = 1; i <= n; i++)//空位上可以选择的数字为:1 ~ n{if(!state[i])//如果数字 i 没有被用过{path[u] = i;//放入空位state[i] = 1;//数字被用,修改状态dfs(u + 1);//填下一个位state[i] = 0;//回溯,取出 i}}
}

例2:P1036 [NOIP 2002 普及组] 选数 - 洛谷

在n个数中选出k个数,并且不同顺序的算一种;相比例1的全排列问题,我们要去掉重复的数量。

因此最后结果要除以n的全排列也就是n的阶乘。

void dfs(int u)
{if (u==k)//当选完k个数后{int sum=0;for (int i=0; i<k; i++){sum+=ans[i];}if (isprimer(sum)){c++;//cout << sum << ' ';}return ;}for (int i=0; i<n; i++){if (!b[i])//判断这个数有没有被选过。{ans[u]=a[i];//选入答案数组中b[i]=true;dfs(u+1);b[i]=false;// 恢复现场}}}

例3:P2404 自然数的拆分问题 - 洛谷

题目可以理解为在1到n这些数中可以重复的选一些数,使其和为n。因此dfs在传参时,可加入一个sum参数。

void dfs(int u,int sum)
{if (sum>n)//当sum大于n时,不符合条件直接结束该路径(我也是在输出结果看到不对后才想起来的){return ;}if (sum==n)//符合预期{int ans[15];if (cun[0]==n){return ;}//剪掉不符合要求的答案for (int i=0; i<u-1; i++){if (cun[i]>cun[i+1]){return ;}//当出现如1 1 1 1 2 1这种重复答案时,直接剪掉,保留1 1 1 1 1 2//cun.clear();}for (int i=0; i<u-1; i++){cout << cun[i] << '+';}//输出最后答案。cout << cun[u-1];cout << endl;return ;}for (int i=1; i<=n; i++){cun[u]=i;dfs(u+1,sum+i);//因为可以重复使用数字,所以无bool数组。//cun[u]=0;}
}

跟例2一样,全排列带来了重复问题

我们只需要判断数组前面的数是否小于后面的数,如果是,就输出。可以有效避免重复问题。

http://www.dtcms.com/wzjs/240915.html

相关文章:

  • 安全的政府网站建设服务商搜索引擎优化的定义
  • 做网站包含的技术2023新一轮病毒叫什么名字
  • 怎么做自己的网址视频优化软件
  • 制作音乐的软件免费网站seo推广多少钱
  • 汕头站扩建有连接华东线吗西安百度竞价推广
  • 武汉网站建设平台网店推广软文范例
  • 外包做网站给公司做网站要多少钱
  • 直接拖拉做网站的软件aso优化怎么做
  • 网站建设什么时候好中国旺旺(00151) 股吧
  • 网站怎么做关键词优化百度入口网站
  • 雅安移动网站建设百度竞价广告怎么收费
  • 珠海舒讯网站建设河北软文搜索引擎推广公司
  • 网站建设服务器什么意思宁波seo排名费用
  • 本地wordpress站点上传文件品牌推广经典案例
  • 网站怎么做用户登录数据库百度推广自己怎么做
  • 日本做a爱片网站石家庄seo网站管理
  • 苏州怎么做网站排名优化媒介星软文平台
  • 崇左市城市投资建设有限公司网站如何创建一个个人网站
  • 专业建设网站应该怎么做app拉新推广
  • 二级网站都在一台服务器怎么做域名兰州seo
  • 购物型网站怎么快速被百度收录厦门seo管理
  • 北京安慧桥网站建设互联网seo是什么
  • wordpress 去除google整站优化 mail
  • 易旅游网站建设重庆seo建站
  • 网站程序是什么意思南宁seo优势
  • 美橙互联送的网站源代码资源平台
  • 网站和网址的区别搜索网站大全排名
  • 龙岩做网站的公司网站推广和优化的原因网络营销
  • asp网站源码后台密码存放在那个文件里?手机百度高级搜索入口在哪里
  • 创建一个网站需要什么条件kol营销模式