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

代码随想录训练营29天|●* 491.递增子序列 * 46.全排列 * 47.全排列 II

class Solution {vector<vector<int>>res;vector<int>vec;void backing(vector<int>& nums,int index){if(vec.size()>=2&&is(vec)){res.push_back(vec);}unordered_set<int> uset; // 使用set对本层元素进行去重for(int i=index;i<nums.size();i++){if(uset.find(nums[i])==uset.end()){vec.push_back(nums[i]);backing(nums,i+1);vec.pop_back();uset.insert(nums[i]);}}}bool is(vector<int>& vec){for(int i=1;i<vec.size();i++){if(vec[i]<vec[i-1])return false;}return true;}
public:vector<vector<int>> findSubsequences(vector<int>& nums) {res.clear();vec.clear();backing(nums,0);return res;}
};
class Solution {vector<vector<int>>res;vector<int>vec;void backing(vector<int>& nums,vector<bool>& used ){if(vec.size()==nums.size()){res.push_back(vec);return ;}for(int i=0;i<nums.size();i++){if(used[i]==false){   used[i]=true;        vec.push_back(nums[i]);backing(nums,used);vec.pop_back();used[i]=false;}}}
public:vector<vector<int>> permute(vector<int>& nums) {vector<bool> used(nums.size(), false);backing(nums,used);return res;}
};
class Solution {vector<vector<int>>res;vector<int>vec;void backing(vector<int>& nums,vector<bool>& used ){if(vec.size()==nums.size()){res.push_back(vec);return ;}for(int i=0;i<nums.size();i++){if (i > 0 && nums[i] == nums[i - 1] && used[i - 1] == false) {continue;}if(used[i]==false){   used[i]=true;        vec.push_back(nums[i]);backing(nums,used);vec.pop_back();used[i]=false;}}}
public:vector<vector<int>> permuteUnique(vector<int>& nums) {sort(nums.begin(), nums.end());vector<bool> used(nums.size(), false);backing(nums,used);return res;}
};
http://www.lryc.cn/news/143470.html

相关文章:

  • uniapp日期选择组件优化
  • AI驱动的大数据创新:探索软件开发中的机会和挑战
  • 国产化-银河麒麟V10系统及docker的安装
  • 计算机毕设 基于机器视觉的二维码识别检测 - opencv 二维码 识别检测 机器视觉
  • Redis原理剖析
  • 【送书活动】AI时代,程序员需要焦虑吗?
  • 什么是 JSON:理解和运用 JSON 的基本概念
  • CSDN每日一练 |『异或和』『生命进化书』『熊孩子拜访』2023-08-27
  • 整数拆分乘积最大
  • 浅谈 Linux 下 vim 的使用
  • leetcode:只出现一次的数字Ⅲ(详解)
  • 【vue3.0 使用组合式定义组件】
  • Tensor-动手学深度学习-李沐_笔记
  • Kafka生产者原理 kafka生产者发送流程 kafka消息发送到集群步骤 kafka如何发送消息 kafka详解
  • Uniapp笔记(七)uniapp打包
  • 软考高级系统架构设计师系列论文七十六:论基于构件的软件开发
  • 基于Thinkphp6框架全新UI的AI网址导航系统源码
  • Html 补充
  • Visual Studio编译出来的程序无法在其它电脑上运行
  • 习题练习 C语言(暑期第二弹)
  • 树莓派使用Nginx+cpolar内网穿透实现无公网IP访问内网本地站点
  • 攻防世界-Web_php_unserialize
  • 云化背景下的接口测试覆盖率自动化检查
  • QCC_BES 音频重采样算法实现
  • 如何使用CSS实现一个3D旋转效果?
  • 联想电脑装系统无法按F9后无法从系统盘启动的解决方案
  • AMEYA360:大唐恩智浦电池管理芯片DNB1168-新能源汽车BMS系统的选择
  • 【Python进阶学习】【Excel读写】使用openpyxl写入xlsx文件
  • Docker(md版)
  • 如何使用CSS实现一个无限循环滚动的图片轮播效果?