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

旅游电商网站建设方案模板网页设计页面设计主要技术

旅游电商网站建设方案模板,网页设计页面设计主要技术,asp企业网站模版,wordpress 底部 时间仅做学习笔记,详细请访问代码随想录 ● 理论基础 ● 77. 组合 ● 理论基础 回溯法解决的问题 回溯法,一般可以解决如下几种问题: 组合问题:N个数里面按一定规则找出k个数的集合 切割问题:一个字符串按一定规则有几…

仅做学习笔记,详细请访问代码随想录

● 理论基础
● 77. 组合

● 理论基础

回溯法解决的问题
回溯法,一般可以解决如下几种问题:

组合问题:N个数里面按一定规则找出k个数的集合
切割问题:一个字符串按一定规则有几种切割方式
子集问题:一个N个数的集合里有多少符合条件的子集
排列问题:N个数按一定规则全排列,有几种排列方式
棋盘问题:N皇后,解数独等等

回溯法模板
这里给出Carl总结的回溯算法模板。

在讲二叉树的递归 (opens new window)中我们说了递归三部曲,这里我再给大家列出回溯三部曲。

回溯函数模板返回值以及参数
在回溯算法中,我的习惯是函数起名字为backtracking,这个起名大家随意。

回溯算法中函数返回值一般为void。

再来看一下参数,因为回溯算法需要的参数可不像二叉树递归的时候那么容易一次性确定下来,所以一般是先写逻辑,然后需要什么参数,就填什么参数。

但后面的回溯题目的讲解中,为了方便大家理解,我在一开始就帮大家把参数确定下来。

回溯函数伪代码如下:

void backtracking(参数)
回溯函数终止条件
既然是树形结构,那么我们在讲解二叉树的递归 (opens new window)的时候,就知道遍历树形结构一定要有终止条件。

所以回溯也有要终止条件。

什么时候达到了终止条件,树中就可以看出,一般来说搜到叶子节点了,也就找到了满足条件的一条答案,把这个答案存放起来,并结束本层递归。

所以回溯函数终止条件伪代码如下:

if (终止条件) {
存放结果;
return;
}
回溯搜索的遍历过程
在上面我们提到了,回溯法一般是在集合中递归搜索,集合的大小构成了树的宽度,递归的深度构成的树的深度。

如图:
在这里插入图片描述
注意图中,我特意举例集合大小和孩子的数量是相等的!

回溯函数遍历过程伪代码如下:

for (选择:本层集合中元素(树中节点孩子的数量就是集合的大小)) {
处理节点;
backtracking(路径,选择列表); // 递归
回溯,撤销处理结果
}
for循环就是遍历集合区间,可以理解一个节点有多少个孩子,这个for循环就执行多少次。

大家可以从图中看出for循环可以理解是横向遍历,backtracking(递归)就是纵向遍历,这样就把这棵树全遍历完了,一般来说,搜索叶子节点就是找的其中一个结果了。

分析完过程,回溯算法模板框架如下:

void backtracking(参数) {
if (终止条件) {
存放结果;
return;
}

for (选择:本层集合中元素(树中节点孩子的数量就是集合的大小)) {处理节点;backtracking(路径,选择列表); // 递归回溯,撤销处理结果
}

}

● 77. 组合

class Solution {
private:vector<vector<int>> result; // 存放符合条件结果的集合vector<int> path; // 用来存放符合条件结果void backtracking(int n, int k, int startIndex) {if (path.size() == k) {result.push_back(path);return;}for (int i = startIndex; i <= n; i++) {path.push_back(i); // 处理节点backtracking(n, k, i + 1); // 递归path.pop_back(); // 回溯,撤销处理的节点}}
public:vector<vector<int>> combine(int n, int k) {result.clear(); // 可以不写path.clear();   // 可以不写backtracking(n, k, 1);return result;}
};
http://www.yayakq.cn/news/459844/

相关文章:

  • 安保企业网站模板太原网站建设包括什么
  • 上海网站建站烟台电子商务产业园网站建设
  • 河南省网站建设哪家好佛山大良网站建设招聘
  • 上海市建设工程 安全质量网站怎样做自己的 优惠卷网站
  • 网站建设 义乌免费域名网站申请
  • 免费注册企业网站陕西最新消息
  • 在哪个网站可以做图文合并建设网站中期要做什么
  • 工作室网站制作多多在线免费观看电视剧
  • 可以做软件的网站wordpress 如何做门户
  • 分类网站建设多少钱萧山品牌网站建设
  • 地方网站推广沈阳网站营销
  • 做商城网站会不会被攻击网站建设项目需求分析流程图
  • 怎么做网站里的资讯厦门网站建设外贸
  • 赤峰网站制作p站代理网址
  • 戴尔网站建设成功的关键百度推广价格
  • 装修公司网站建设的意义仿58网站怎么做
  • 网站主题及风格宝塔 伪静态 wordpress
  • python是做网站的吗城市建设规划网站
  • 网站 怎么做百度才能搜索出来中山做网站做的好的公司
  • 庆阳网站设计费用做外贸的网站主要有哪些
  • 如何自己建立网站在网站上如何做天气预报栏
  • 系统网站主题有哪些问题成都网站建设有哪些
  • 企业网站建设费用预算在线建设网站 源代码
  • 专业手机网站建设公司排名上海传媒公司艺人
  • 网站开发的学习方法网站建设的经济可行性分析
  • 网站的建设会计入哪个科目泊头网站建设公司
  • 网站 硬件方案网络营销的步骤和流程
  • 晋中网站seo代做百度首页排名价格
  • 怎么做多语言网站成都企业网站网络营销
  • 卖做游戏点卡网站创业室内设计师工资一般多少