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

wordpress文章摘要插件深圳网络推广seo软件

wordpress文章摘要插件,深圳网络推广seo软件,蛋糕电子商务网站建设方案,网站建设与运营 好考吗前言 回溯章节第11篇。记录 八十四【46.全排列】 回溯学习过:组合问题、切割问题、子集问题。 本文是排列问题。 一、题目阅读 给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1: 输入&…

前言

回溯章节第11篇。记录 八十四【46.全排列】
回溯学习过:组合问题、切割问题、子集问题。
本文是排列问题。


一、题目阅读

给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。

示例 1:

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

示例 2:

输入:nums = [0,1]
输出:[[0,1],[1,0]]

示例 3:

输入:nums = [1]
输出:[[1]]

提示:

1 <= nums.length <= 6
-10 <= nums[i] <= 10
nums 中的所有整数 互不相同

二、尝试实现

2.1分析题目,确定方法

  1. 记录 六十三【回溯章节开篇】讲过回溯解决哪些问题。题目直白指出求排列,解决排列用回溯
  2. 确定回溯之后,需要构造一个树形结构。按照树形结构方便实现递归。以示例1为例:
    在这里插入图片描述
  3. 搜集结构都是在叶子节点,所以有终止条件:和子集问题不一样;
  4. 可选元素不是在已选元素之后继续选择,和组合不一样。
  5. 发现:一个排序需要用到集合所有的元素,需要记录这个元素有没有被选过。所以用used数组表示当前已有的排列中有没有该元素

2.2回溯思路

  1. 确定返回值:用全局变量 vector<vector< int>> result; vector< int> temp; 搜集结果。所以返回值是void。
  2. 确定参数:
  • 需要输入集合:const vector< int>& nums;
  • 需要used数组:vector< bool>& used。表示当前已有的排列中有没有该元素。
  1. 确定终止条件:当temp.size() == nums.size(),temp中已经是一个排列了。就该return。
  2. 确定逻辑:
  • for循环,从0开始,到nums.size()结束;
  • 如果used == false,说明排列中还没有这个元素,那么可以放入temp并且used改成true;否则,continue;
  • 放入temp之后,递到下一层;
  • 回溯:把元素pop并且used = false。

代码实现【回溯】

class Solution {
public:vector<vector<int>> result;vector<int> temp;void backtracking(const vector<int>& nums,vector<bool>& used){if(temp.size() == nums.size()){result.push_back(temp);return;}for(int i = 0;i < nums.size();i++){if(used[i] == false){temp.push_back(nums[i]);used[i] = true;backtracking(nums,used);temp.pop_back();used[i] = false;}}return;}vector<vector<int>> permute(vector<int>& nums) {result.clear();temp.clear();vector<bool> used(nums.size(),false);//有没有被选到backtracking(nums,used);return result;}
};

三、参考学习

【46.全排列】 参考学习链接

  1. 参考给的思路和方法与尝试实现中一致。
  2. 分析时间复杂度:递归次数 * 每次递归的时间复杂度。
  • 递归次数:第一层for循环可选n个元素,是排列的第一个元素;第二层for循环可选n-1个元素,是排列的第二个元素;第三层for循环可选n-2个元素,是排列的第三个元素……直到最后一个元素。所以一个集合有 n! 个排列。需要递归 n! 次。
  • 每次递归的时间复杂度:操作单元是处理——递归——回溯完整过程。O(1)。
  • 所以时间复杂度是O(n!)。
  1. 空间复杂度:递归深度 * 每次递归的空间复杂度。递归深度:n,集合的大小;每次递归的空间复杂度是O(1),因为使用同一个used数组、result数组、temp数组空间,没有新开辟别的大小。所以空间复杂度是O(n)。

总结

在这里插入图片描述
(欢迎指正,转载标明出处)

http://www.hrbkazy.com/news/13823.html

相关文章:

  • 国内做的好的帽子网站电工培训机构
  • 泰安公司北京seo教师
  • 用视频做影视的网站软文发布平台
  • 建行官方网站seo关键词排名优化要多少钱
  • 文件大小 wordpressseo引擎优化是什
  • 淘宝客必须做网站吗搜索引擎推广的方法有哪些
  • 网页制作购物网站今天的头条新闻
  • 番禺网站开发价格seo外链收录
  • 做网站需要的资料360营销推广
  • 石家庄做网站哪家好北京搜索引擎推广公司
  • 泉山网站开发南安网站建设
  • 怎么建立类似百度问答的网站正规电商培训学校排名
  • 网站建站华为云小型项目外包网站
  • 网站建设安全性指标百度搜索引擎工作原理
  • 网站新媒体建设新闻最新消息
  • 郴州 网站建设石家庄seo优化
  • 做竞价网站服务器多少钱百度百度一下你就知道
  • 网站开发中 html软文广告发稿
  • 自己做的网站涉黄百度营销推广登录
  • 杭州 网站建设网站长春seo优化
  • 南京市公共建设中心网站营销型网站是什么意思
  • 装修包工头接活网站最新国际新闻事件今天
  • 怎么做网站模块广东今日最新疫情通报
  • 微信小程序论坛seocui cn
  • 建设银行扬中网站厦门网站到首页排名
  • 政府网站建设服务方案权重查询站长工具
  • 企业网站模板建站产品营销推广的方案
  • 17网站一起做网店新塘北京seo网站优化培训
  • vi企业形象设计是什么seo优化关键词分类
  • 公司做网站的发票能抵扣吗手机百度2020