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

沈阳公司建站免费学习网站建设

沈阳公司建站,免费学习网站建设,网站怎么更换页面图片,公众号和网站先做哪个Leetcode 491. 非递减子序列 链接:491. 非递减子序列 thought: 设 stack 中最后一个值的位置为 last。如果 stack 为空,则 last -1。 设当前正在处理的位置为 pos。如果在 nums 的子区间 [last1, pos) 中,存在和 nums[pos] 相同的值&…

Leetcode 491. 非递减子序列

链接:491. 非递减子序列

thought:

  • 设 stack 中最后一个值的位置为 last。如果 stack 为空,则 last = -1。
    设当前正在处理的位置为 pos。
  • 如果在 nums 的子区间 [last+1, pos) 中,存在和 nums[pos] 相同的值,则当前 nums[pos] 必须丢弃,不然会产生重复的子序列。

在这里插入图片描述

完整C++代码如下

class Solution {
public:vector<vector<int>> findSubsequences(vector<int>& nums) {vector<vector<int>> res;vector<int> path;backtracking(res, nums, path, 0);return res;}private:void backtracking(vector<vector<int>>& res, vector<int>& nums, vector<int>& path, int start) {if (path.size() >= 2) // 如果当前递增子序列长度大于等于2,则将其加入结果集res.push_back(path);unordered_set<int> seen; // 用一个集合来记录当前层已经使用过的数字,避免重复//注意为当前层for (int i = start; i < nums.size(); ++i) {if ((!path.empty() && nums[i] < path.back()) || seen.count(nums[i])) // 如果当前数字小于上一个数字(不符合递增)或者已经使用过,则跳过continue;seen.insert(nums[i]); // 将当前数字加入集合path.push_back(nums[i]); // 将当前数字加入递增序列backtracking(res, nums, path, i + 1); // 递归搜索下一个位置path.pop_back(); // 回溯,将当前数字从递增序列中删除}}
};

Leetcode 46. 全排列

链接:46. 全排列

thought:

设置bool数组记录当前位置数是否已经使用过,若使用过直接跳过

完整C++代码如下

class Solution {
public:vector<vector<int>> permute(vector<int>& nums) {vector<int>path;vector<vector<int>>res;vector<bool>used(nums.size(),false);backtracking(nums,path,res,used);return res;}void backtracking(vector<int>& nums,vector<int>&path,vector<vector<int>>&res,vector<bool>&used){if(path.size()==nums.size()){res.push_back(path);return;}for(int i=0;i<nums.size();i++){if(used[i])continue;used[i]=true;path.push_back(nums[i]);backtracking(nums,path,res,used);//递归path.pop_back();//回溯used[i]=false;//回溯}}
};

Leetcode 47. 全排列 II

链接:47. 全排列 II

class Solution {
private:vector<vector<int>> result;vector<int> path;void backtracking (vector<int>& nums, vector<bool>& used) {// 此时说明找到了一组if (path.size() == nums.size()) {result.push_back(path);return;}for (int i = 0; i < nums.size(); i++) {// used[i - 1] == true,说明同一树枝nums[i - 1]使用过// used[i - 1] == false,说明同一树层nums[i - 1]使用过// 如果同一树层nums[i - 1]使用过则直接跳过if (i > 0 && nums[i] == nums[i - 1] && used[i - 1] == false) {continue;}if (used[i] == false) {used[i] = true;path.push_back(nums[i]);backtracking(nums, used);path.pop_back();used[i] = false;}}}
public:vector<vector<int>> permuteUnique(vector<int>& nums) {result.clear();path.clear();sort(nums.begin(), nums.end()); // 排序vector<bool> used(nums.size(), false);backtracking(nums, used);return result;}
};
http://www.yayakq.cn/news/12527/

相关文章:

  • 网站建设的自查报告手机app开发定制公司
  • 东莞模块网站建设烟台制作网站
  • 佛山服务类网站建设网站制作 php
  • 网站建设預算年度工作总结
  • 网站备案查询验证码错误广告投放优化师
  • 网站上怎么做推广比较好呢做网站时图片的分辨率是多少
  • 电子商务网站cms主页网站建设
  • 中信建设有限公司是央企吗邢台谷歌seo
  • 天天斗地主官方网站开发网站建设技术及服务承诺
  • 甘肃建设局网站wordpress 屏蔽特定国家ip
  • 门户网站创新的方式有电子商务网站开发的目的是什么
  • 创新创业营销策略网站建设等福州网站建设思企
  • 手机套 东莞网站建设企业官网wordpress主题下载
  • 网站地址ip域名查询重庆市招投标信息网
  • 我要发布文章到网站上推广 哪些网站最好网站建设桔子科技
  • 职高网站建设知识点WordPress一键环境
  • 如何自己做视频网站有成crm
  • 手机网站百度关键词排名怎样设置一个属于自己的网站
  • 网站举报查询运营一个网站的费用
  • 网站做支付端口的费用营销策略怎么写模板
  • 怎么自己建网站wordpress做电影网站
  • 磁力网站怎么做的源码德州网络科技有限公司
  • 西部数码网站管理助手 伪静态网站开发建站微信公众号小程序
  • 怎样宣传网站互联网建造公司有哪些
  • 企业网站建站元素能做游戏的软件
  • 网站图标用代码代替高端h5手机网站设计案例
  • 什么网站可以推广广告wordpress 前台多余代码
  • 迈网科技 官方网站网站 兼容性
  • 网站开发背景400字wordpress黑色主题下载
  • 做网站加班多吗惠州 网站建设