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

受欢迎的医疗网站建设厦门网络关键词排名

受欢迎的医疗网站建设,厦门网络关键词排名,wordpress超简洁企业主题,北京官方网站网这段代码的目的是计算给定整数数组的所有全排列(permutations),并返回一个包含所有排列的二维数组。 思路解析 在这段代码中,采用了 深度优先搜索(DFS) 和 回溯 的方法来生成所有的排列。 关键步骤&#xf…

这段代码的目的是计算给定整数数组的所有全排列(permutations),并返回一个包含所有排列的二维数组。

思路解析

在这段代码中,采用了 深度优先搜索(DFS)回溯 的方法来生成所有的排列。

关键步骤:

1. 回溯:我们通过交换数组中的元素,将数组的每个元素依次放置到每个位置,生成所有的排列组合。

2. 递归:每次递归处理当前索引位置的元素,继续处理下一个位置,直到递归到数组的末尾,表示完成一个排列。

3. 交换回溯:在每次递归后,通过交换操作还原数组的顺序,避免对后续递归产生影响。

代码解析


class Solution {public:vector<vector<int>> ans;  // 用于存储所有的排列vector<vector<int>> permute(vector<int>& nums) {dfs(nums, 0);  // 从数组的第一个位置开始深度优先搜索return ans;  // 返回所有的排列}void dfs(vector<int>& nums, int n) {// 如果当前的索引等于数组的长度,说明已经形成了一个排列if (n == nums.size()) {ans.push_back(nums);  // 将当前排列加入结果集中return;}// 遍历当前索引位置后的所有元素for (int i = n; i < nums.size(); i++) {swap(nums[i], nums[n]);  // 将第 i 个元素与第 n 个元素交换dfs(nums, n + 1);  // 递归处理下一个位置swap(nums[i], nums[n]);  // 交换回去,恢复原数组状态(回溯)}}};

详细注释

1. vector<vector<int>> ans;:

• 用于存储所有的排列组合。

2. vector<vector<int>> permute(vector<int>& nums):

• permute 是主函数,接受一个整数数组 nums 作为输入,返回一个包含所有排列的二维数组。

• dfs(nums, 0) 从 nums 的第 0 个位置开始深度优先搜索。

3. void dfs(vector<int>& nums, int n):

• dfs 是深度优先搜索的核心函数,负责递归生成排列。

• nums 是待排列的数组,n 是当前递归处理的索引位置。

4. if (n == nums.size()):

• 如果当前的索引 n 等于数组的大小,说明已经将所有元素排列完毕,形成了一个有效的排列。

• ans.push_back(nums) 将当前的排列(即 nums 数组的状态)加入结果集 ans。

5. for (int i = n; i < nums.size(); i++):

• 遍历当前索引 n 之后的每一个元素,通过交换生成不同的排列。

6. swap(nums[i], nums[n]);:

• 交换 nums[i] 和 nums[n],将 nums[i] 放到当前的位置 n。这样可以生成一个新的排列组合。

7. dfs(nums, n + 1):

• 递归调用 dfs,将处理下一个位置的元素。即当前元素已放置好,继续处理下一个索引。

8. swap(nums[i], nums[n]);:

• 交换回去,恢复原数组状态,这样可以进行下一轮的排列生成(即回溯)。这是为了确保后续的排列生成不会受到之前交换的影响。

好的,接下来我会详细地继续补充并完成整个 深度优先搜索(DFS)回溯 的运行步骤,直到所有排列都生成完毕。

输入数组:

nums = [1, 2, 3]

运行步骤:

我们通过 DFS 和回溯的方法生成 nums 数组的所有排列。

初始状态:

• 输入:nums = [1, 2, 3]

• ans = [](最终存储所有排列的结果)

第 1 层递归:n = 0 (处理第一个位置)

• 当前节点的起始值是 nums = [1, 2, 3],n = 0,遍历 i = 0 到 i = 2。

1. 第 1 次交换:swap(nums[0], nums[0]),数组未变,仍为 [1, 2, 3]。

• 递归调用 dfs(nums, 1),进入处理第二个位置。

第 2 层递归:n = 1 (处理第二个位置)

• 当前节点的起始值是 nums = [1, 2, 3],n = 1,遍历 i = 1 到 i = 2。

1. 第 1 次交换:swap(nums[1], nums[1]),数组未变,仍为 [1, 2, 3]。

• 递归调用 dfs(nums, 2),进入处理第三个位置。

第 3 层递归:n = 2 (处理第三个位置)

• 当前节点的起始值是 nums = [1, 2, 3],n = 2,遍历 i = 2 到 i = 2(只剩下一个位置)。

1. 第 1 次交换:swap(nums[2], nums[2]),数组未变,仍为 [1, 2, 3]。

• 递归调用 dfs(nums, 3),这时 n == nums.size(),说明当前排列已经完成。

2. 将 [1, 2, 3] 加入到 ans 中。

• ans = [[1, 2, 3]]

回溯:恢复状态

• 交换回去,恢复原数组 [1, 2, 3]。

• 返回到 n = 1,继续处理 i = 2。

2. 第 2 次交换:swap(nums[1], nums[2]),数组变为 [1, 3, 2]。

• 递归调用 dfs(nums, 2),进入处理第三个位置。

第 3 层递归:n = 2 (处理第三个位置)

• 当前节点的起始值是 nums = [1, 3, 2],n = 2,遍历 i = 2 到 i = 2(只剩下一个位置)。

1. 第 1 次交换:swap(nums[2], nums[2]),数组未变,仍为 [1, 3, 2]。

• 递归调用 dfs(nums, 3),这时 n == nums.size(),说明当前排列已经完成。

2. 将 [1, 3, 2] 加入到 ans 中。

• ans = [[1, 2, 3], [1, 3, 2]]

回溯:恢复状态

• 交换回去,恢复原数组 [1, 3, 2]。

• 返回到 n = 1,恢复原数组 [1, 2, 3]。

• 返回到 n = 0,恢复原数组 [1, 2, 3]。

第 2 次交换:n = 0 (处理第一个位置)

3. 第 2 次交换:swap(nums[0], nums[1]),数组变为 [2, 1, 3]。

• 递归调用 dfs(nums, 1),进入处理第二个位置。

第 2 层递归:n = 1 (处理第二个位置)

• 当前节点的起始值是 nums = [2, 1, 3],n = 1,遍历 i = 1 到 i = 2。

1. 第 1 次交换:swap(nums[1], nums[1]),数组未变,仍为 [2, 1, 3]。

• 递归调用 dfs(nums, 2),进入处理第三个位置。

第 3 层递归:n = 2 (处理第三个位置)

• 当前节点的起始值是 nums = [2, 1, 3],n = 2,遍历 i = 2 到 i = 2(只剩下一个位置)。

1. 第 1 次交换:swap(nums[2], nums[2]),数组未变,仍为 [2, 1, 3]。

• 递归调用 dfs(nums, 3),这时 n == nums.size(),说明当前排列已经完成。

2. 将 [2, 1, 3] 加入到 ans 中。

• ans = [[1, 2, 3], [1, 3, 2], [2, 1, 3]]

回溯:恢复状态

• 交换回去,恢复原数组 [2, 1, 3]。

• 返回到 n = 2,继续处理 i = 2。

2. 第 2 次交换:swap(nums[1], nums[2]),数组变为 [2, 3, 1]。

• 递归调用 dfs(nums, 2),进入处理第三个位置。

第 3 层递归:n = 2 (处理第三个位置)

• 当前节点的起始值是 nums = [2, 3, 1],n = 2,遍历 i = 2 到 i = 2(只剩下一个位置)。

1. 第 1 次交换:swap(nums[2], nums[2]),数组未变,仍为 [2, 3, 1]。

• 递归调用 dfs(nums, 3),这时 n == nums.size(),说明当前排列已经完成。

2. 将 [2, 3, 1] 加入到 ans 中。

• ans = [[1, 2, 3], [1, 3, 2], [2, 1, 3], [2, 3, 1]]

回溯:恢复状态

• 交换回去,恢复原数组 [2, 3, 1]。

• 返回到 n = 1,恢复原数组 [2, 1, 3]。

• 返回到 n = 0,恢复原数组 [1, 2, 3]。

第 3 次交换:n = 0 (处理第一个位置)

4. 第 3 次交换:swap(nums[0], nums[2]),数组变为 [3, 2, 1]。

• 递归调用 dfs(nums, 1),进入处理第二个位置。

第 2 层递归:n = 1 (处理第二个位置)

• 当前节点的起始值是 nums = [3, 2, 1],n = 1,遍历 i = 1 到 i = 2。

1. 第 1 次交换:swap(nums[1], nums[1]),数组未变,仍为 [3, 2, 1]。

• 递归调用 dfs(nums, 2),进入处理第三个位置。

第 3 层递归:n = 2 (处理第三个位置)

• 当前节点的起始值是 nums = [3, 2, 1],n = 2,遍历 i = 2 到 i = 2(只剩下一个位置)。

1. 第 1 次交换:swap(nums[2], nums[2]),数组未变,仍为 [3, 2, 1]。

• 递归调用 dfs(nums, 3),这时 n == nums.size(),说明当前排列已经完成。

2. 将 [3, 2, 1] 加入到 ans 中。

• ans = [[1, 2, 3], [1, 3, 2], [2, 1, 3], [2, 3, 1], [3, 2, 1]]

回溯:恢复状态

• 交换回去,恢复原数组 [3, 2, 1]。

• 返回到 n = 2,恢复原数组 [3, 2, 1]。

• 返回到 n = 1,恢复原数组 [3, 2, 1]。

• 返回到 n = 0,恢复原数组 [1, 2, 3]。

最终结果

最终生成的排列 ans 中包含了所有可能的排列:

ans = [[1, 2, 3], [1, 3, 2], [2, 1, 3], [2, 3, 1], [3, 2, 1], [3, 1, 2]]

总结

1. DFS 遍历:通过递归逐个处理每个位置,生成所有可能的字符组合。

2. 回溯:通过交换和恢复数组状态,确保生成所有排列。

3. 最终生成了所有的排列,并存储在 ans 中。

这样,我们使用回溯和 DFS 的方法成功计算出了所有的排列,并保存在 ans 数组中。

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

相关文章:

  • 手机网站 兼容网站seo批量查询工具
  • 不会代码怎么做外贸网站深圳网络品牌推广公司
  • 乡镇网站建设抖音推广引流
  • 网站建设会议报道做seo前景怎么样
  • 怎么创立网站 优帮云sq网站推广
  • 萍乡网站推广建立网站需要什么技术
  • 唐山做网站公司永州网站seo
  • 做微信商城网站公司企业网站建设方案论文
  • 哪个网站可以做危险化学品供求商品seo优化是什么意思
  • 网站建设修改百度秒收录软件
  • 淘宝做的网站优化合肥百度推广优化排名
  • 哪些园林网站可以做外链从事网络销售都有哪些平台呢
  • 电子商务网站建设移动电商开发seo建站是什么
  • 河南企业网站制作搜索引擎排名规则
  • 门户网站建设存在问题与不足乔拓云建站平台
  • 邢台做网站的公司哪家好?有域名有服务器怎么做网站
  • 惠州外贸网站建设品牌推广和品牌营销
  • 大武口做网站的torrentkitty磁力官网
  • 北京科技网站建设seo课程心得体会
  • 沈阳网页设计公司排名青岛神马排名优化
  • 周口建设路网站西地那非片吃了多久会硬起来
  • 重庆在线高校开放课程平台登录文山seo公司
  • 做厂房出租有那些推广网站全网营销推广平台有哪些
  • 大庆市建设局网站肇庆疫情最新消息
  • 什么是营销型的网站媒体吧软文平台
  • 网站在公司做有什么要求吗百度竞价排名魏则西事件分析
  • 学校网站网站建设网络推广中心
  • 什么网站可以免费做视频的软件下载国内免费ip地址
  • 网站用视频做背景百度登录个人中心
  • 国内免费网站空间1688官网入口