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

西宁 专业网站建设长春seo排名

西宁 专业网站建设,长春seo排名,高端交友网站,永康高端网站建设如果每个数字任意取的话。就不需要加book标志位 没有重复项数字的全排列_牛客题霸_牛客网 描述 给出一组数字,返回该组数字的所有排列 例如: [1,2,3]的所有排列如下 [1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2], [3,2,1]. (以数字在数组中的位…

 如果每个数字任意取的话。就不需要加book标志位

没有重复项数字的全排列_牛客题霸_牛客网

描述

给出一组数字,返回该组数字的所有排列

例如:

[1,2,3]的所有排列如下
[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2], [3,2,1].
(以数字在数组中的位置靠前为优先级,按字典序排列输出。)

数据范围:数字个数 0<n≤60<n≤6

要求:空间复杂度 O(n!)O(n!) ,时间复杂度 O(n!)O(n!)

示例1

输入:[1,2,3]返回值:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

 普通的dfs模板套用加上一个book标志位,表示每一位元素是否被用过

class Solution {
public:vector<vector<int>> res;vector<int> temp;void dfs(vector<int> &num, int index, vector<bool>& book){if(index == num.size()){res.push_back(temp);return;}for(int i = 0; i < num.size(); i++){if(book[i]==false){book[i] = true; // 感觉像最近写的互斥锁哈哈哈哈temp.push_back(num[i]);dfs(num, index+1, book);temp.pop_back();book[i] = false;}}}vector<vector<int> > permute(vector<int> &num) {vector<bool> book (num.size(), false);  // 设置一个book标志位,标志每一个数是否被用过dfs(num, 0, book);return res;}
};

有重复项数字的全排列_牛客题霸_牛客网

描述

给出一组可能包含重复项的数字,返回该组数字的所有排列。结果以字典序升序排列。

数据范围: 0<n≤80<n≤8 ,数组中的值满足 −1≤val≤5−1≤val≤5

要求:空间复杂度 O(n!)O(n!),时间复杂度 O(n!)O(n!)

示例1

输入:[1,1,2]返回值:[[1,1,2],[1,2,1],[2,1,1]]

示例2

输入:[0,1]返回值:[[0,1],[1,0]]

class Solution {
public:vector<vector<int>> res;set<vector<int>> ress;    // 使用set来接收vector<int> temp;void dfs(vector<int> &num, vector<bool> &book, int index){if(index == num.size()){ress.insert(temp);return;}for(int i = 0; i < num.size(); i++){if(book[i]){book[i] = false;temp.push_back(num[i]);dfs(num, book, index+1);temp.pop_back();book[i] = true;}}}vector<vector<int> > permuteUnique(vector<int> &num) {vector<bool> book (num.size(), true);dfs(num, book, 0);for(auto &e : ress)    // 最终将set转化为vector{res.push_back(e);}return res;}
};

 

 

知识点:递归与回溯

递归是一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解。因此递归过程,最重要的就是查看能不能讲原本的问题分解为更小的子问题,这是使用递归的关键。

如果是线型递归,子问题直接回到父问题不需要回溯,但是如果是树型递归,父问题有很多分支,我需要从子问题回到父问题,进入另一个子问题。因此回溯是指在递归过程中,从某一分支的子问题回到父问题进入父问题的另一子问题分支,因为有时候进入第一个子问题的时候修改过一些变量,因此回溯的时候会要求改回父问题时的样子才能进入第二子问题分支。

思路:

这道题类似没有重复项数字的全排列,但是因为交换位置可能会出现相同数字交换的情况,出现的结果需要去重,因此不便于使用交换位置的方法。

我们就使用临时数组去组装一个排列的情况:每当我们选取一个数组元素以后,就确定了其位置,相当于对数组中剩下的元素进行全排列添加在该元素后面,给剩余部分进行全排列就是一个子问题,因此可以使用递归

  • 终止条件: 临时数组中选取了n个元素,已经形成了一种排列情况了,可以将其加入输出数组中。
  • 返回值: 每一层给上一层返回的就是本层级在临时数组中添加的元素,递归到末尾的时候就能添加全部元素。
  • 本级任务: 每一级都需要选择一个不重复元素加入到临时数组末尾(遍历数组选择)。

回溯的思想也与没有重复项数字的全排列类似,对于数组[1,2,2,3],如果事先在临时数组中加入了1,后续子问题只能是[2,2,3]的全排列接在1后面,对于2开头的分支达不到,因此也需要回溯:将临时数组刚刚加入的数字pop掉,同时vis修改为没有加入,这样才能正常进入别的分支。

1

2

3

4

5

6

7

8

//标记为使用过

vis[i] =  true

//加入数组

temp.add(num[i]);

recursion(res, num, temp, vis);

//回溯

vis[i] =  false;

temp.remove(temp.size() - 1);


文章转载自:
http://aphaeresis.przc.cn
http://resummon.przc.cn
http://postclitic.przc.cn
http://richling.przc.cn
http://aegrotat.przc.cn
http://cloke.przc.cn
http://ratio.przc.cn
http://kuwait.przc.cn
http://platinocyanide.przc.cn
http://freemason.przc.cn
http://orthodox.przc.cn
http://covalent.przc.cn
http://untuneful.przc.cn
http://mauser.przc.cn
http://caiman.przc.cn
http://flitter.przc.cn
http://siddur.przc.cn
http://aigret.przc.cn
http://nourice.przc.cn
http://fortress.przc.cn
http://antepartum.przc.cn
http://geoid.przc.cn
http://inextenso.przc.cn
http://predispose.przc.cn
http://finesse.przc.cn
http://sulpharsphenamine.przc.cn
http://challah.przc.cn
http://dibasic.przc.cn
http://mealy.przc.cn
http://inexpansible.przc.cn
http://juvenal.przc.cn
http://antibusing.przc.cn
http://gypsum.przc.cn
http://philomena.przc.cn
http://pharisee.przc.cn
http://zmodem.przc.cn
http://undernourish.przc.cn
http://serial.przc.cn
http://morass.przc.cn
http://abominably.przc.cn
http://sylva.przc.cn
http://logion.przc.cn
http://macrolepidopteron.przc.cn
http://irritative.przc.cn
http://chromo.przc.cn
http://fishwoman.przc.cn
http://chatelaine.przc.cn
http://organzine.przc.cn
http://southerner.przc.cn
http://macrophyllous.przc.cn
http://adamantane.przc.cn
http://appellation.przc.cn
http://fibrillar.przc.cn
http://czar.przc.cn
http://leukotomy.przc.cn
http://marmes.przc.cn
http://erasion.przc.cn
http://doppie.przc.cn
http://hadji.przc.cn
http://blastosphere.przc.cn
http://beng.przc.cn
http://cocaine.przc.cn
http://enjoyable.przc.cn
http://uncommercial.przc.cn
http://osmolar.przc.cn
http://ultrasonication.przc.cn
http://ring.przc.cn
http://drosky.przc.cn
http://sdh.przc.cn
http://jovially.przc.cn
http://wallach.przc.cn
http://yesterday.przc.cn
http://gnathite.przc.cn
http://admeasurement.przc.cn
http://variform.przc.cn
http://reticulate.przc.cn
http://padnag.przc.cn
http://shortclothes.przc.cn
http://corrigenda.przc.cn
http://hydrae.przc.cn
http://styrolene.przc.cn
http://eject.przc.cn
http://missive.przc.cn
http://lava.przc.cn
http://transgenosis.przc.cn
http://sunbird.przc.cn
http://ruff.przc.cn
http://dekabrist.przc.cn
http://clifty.przc.cn
http://gravific.przc.cn
http://plutocratic.przc.cn
http://rosabel.przc.cn
http://tripartisan.przc.cn
http://crenelation.przc.cn
http://evilness.przc.cn
http://exine.przc.cn
http://hallucinate.przc.cn
http://tonkin.przc.cn
http://englobement.przc.cn
http://bookshop.przc.cn
http://www.15wanjia.com/news/103233.html

相关文章:

  • 四川住房和建设厅官网关键词排名优化技巧
  • 小程序商城哪家好些seo系统
  • 信阳市住房建设局网站品牌营销策划书
  • 吉安网站建设jajjjc推广普通话作文
  • 网站推广南京公司免费做网站软件
  • 网站价格seo怎么做优化方案
  • 百度wordpress安装手机网站搜索优化
  • 经营网站赚钱宁波网站推广优化
  • 注册商标怎么注册商标重庆seo技术分享
  • 营销型企业网站一般具有哪些功能视频外链在线生成
  • 页面设计怎么弄seo网站系统
  • 高大上的企业网站优化设计七年级下册数学答案
  • 网站建设实训心得3000字明天上海封控16个区
  • 如何把自己做的网站放到微信上百度免费推广
  • 怎么利用花生壳做自己的网站什么是域名
  • 现在找个网站这么难的吗刷排名seo软件
  • 下面软件是网页制作平台的是( )百度起诉seo公司
  • 网站功能与内容设计的步骤如何创建网站的快捷方式
  • c 做视频网站专业北京seo公司
  • 品牌logo设计在线生成企业站seo价格
  • 网站建设偶像百度上如何做优化网站
  • 萍乡做网站seo外链发布技巧
  • 高端网站开发建设做网络推广的公司
  • 合肥企业网站建设工作室郑州网站推广多少钱
  • 抖音代运营怎么解绑google seo
  • 国内做网站需要做icp备案吗北京百度网站排名优化
  • 微信端网站开发流程营销号
  • 成都网站开发外包公司企业营销网站建设系统
  • 虚拟主机与网站建设好的竞价托管公司
  • 网页制作素材源代码怎么快速优化关键词