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

湖北做网站教程哪家好湘潭seo培训

湖北做网站教程哪家好,湘潭seo培训,2022年税收优惠政策有哪些,泽州县住房保障和城乡建设局网站曾经我们讲过枚举算法,那假设我们把枚举算法应用到搜索里呢? 1.搜索枚举 以前我们在进行枚举的时候是用了多层循环嵌套,但是当枚举的变量过多或者是输入的数量的时候就很难利用循环完成枚举了,不过我们可以尝试利用搜索进行枚举。…

曾经我们讲过枚举算法,那假设我们把枚举算法应用到搜索里呢?

1.搜索枚举

以前我们在进行枚举的时候是用了多层循环嵌套,但是当枚举的变量过多或者是输入的数量的时候就很难利用循环完成枚举了,不过我们可以尝试利用搜索进行枚举。

通常,我们通过一个 dfs 函数来完成搜索枚举,而通过参数表示当前状态。例如在大部分搜索枚举问题中,可以通过 step 或 depth 表示当前枚举层数,或使用 n 表示已经选入的数量,亦或在对于一些对 和 有限制的问题中,使用 sum 表示已经选入的数量之和。

让我们看一道能够使用搜索枚举实现的题目:现有方程a[1]x[1]+a[2]x[2]+a[3]x[3]+...+a[n]x[n]=0 2≤n≤10,−5≤a[i]≤5,−2≤x[i]≤2,x[i]∈Z

求解的总数。

Z 表示整数集合,其包括了:全体正整数、全体负整数和零。

能够估算所有的状态总数在 10的5次方∼10的7次方,能够枚举全部的状态。虽然能够使用 10 个循环完成,但此处使用搜索枚举更为方便。

int ans = 0;
void dfs(int dep, int sum) {if (dep == n) {if (sum == 0){ans++;}return;}for (int i = -2; i <= 2; i++) {dfs(dep + 1, sum + a[dep] * i);}
}

在很多搜索枚举的问题中,会要求我们打印解的具体内容,那么可使用数组来保存具体的解。如对于之前求方程解的问题,可将代码修改为:

int ans[15];
void dfs(int dep, int sum) {if (dep == n) {if (sum == 0){for (int i = 0; i < n; i++) {cout << ans[i] << " ";}cout << endl;}return ;}for (int i = -2; i <= 2; i++) {ans[dep] = i;dfs(dep + 1, sum + a[dep] * i);}
}

把在dep这一层选择的情况放在ans[dep]位置,ans数组就记下了目前枚举到的情况。n

在搜索枚举的过程中,我们能够根据题目的一些性质,对求解的过程进行剪枝优化,这个我们以后也会学到。但是对大部分题目来说,搜索枚举很有可能达到状态的上限,所以很有必要在决定使用搜索枚举之前确定状态的总数。

http://www.ds6.com.cn/news/57721.html

相关文章:

  • 做音乐网站是不是侵权网站为什么要seo
  • 网站建设好了还要收取维护费网页优化seo广州
  • 做网站排名赚钱吗广告推广文案
  • 做网赌需要在哪些网站投广告提高工作效率心得体会
  • 嘉兴公司做网站企业员工培训课程内容
  • 江西省建设监督网站百度app下载安装官方免费版
  • 苏州知名网站建设设计seo的中文含义
  • wordpress图文标题一体布局南京百度搜索优化
  • 我的网站在百度搜不到哪家公司做seo
  • tab导航 wordpress郑州搜狗关键词优化顾问
  • 网站首页图片轮转代码 很好用营销网络建设
  • 基金会网站建设方案网站友链查询源码
  • 公司架设网站费用怎么做分录软文外链购买平台
  • 修改wordpress发表评论优化大师免费下载安装
  • 深圳市做网站的搜索引擎google
  • 网站建设中心四川seo
  • 商业网站建设费用网络营销方案3000字
  • 网站备案登记查询系统如何提高百度搜索排名
  • 运城网站建设价格三十个知识点带你学党章
  • 高端制作网站设计seo平台怎么样
  • 租用服务器一般是谁帮助维护网站安全信息推广服务
  • 广州网站建设网站制作公司seo免费优化
  • 北京口碑最好的装修公司泰州百度seo公司
  • 网站有备案 去掉备案百度竞价推广效果怎么样
  • 丰涵网站建设科技友情链接在线观看
  • 优秀手机网站模板图片企业老板培训课程
  • 晓风彩票门户网站建设网络推广公司口碑
  • 上海人才网北京seo教师
  • wordpress图片css企业站seo案例分析
  • 亚马逊网站建设做什么营业推广的概念