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

html5 服装网站重庆华鼎达网站建设

html5 服装网站,重庆华鼎达网站建设,WordPress资讯网站,毕业设计做网站选题这道题的难点依旧是去重,但是与之前做过的子集类问题的区别就是,这里是求子序列,意味着我们不能先给数组中的元素排序。因为子序列中的元素的相对位置跟原数组中的相对位置是一样的,如果我们改变数组中元素的顺序,子序…

这道题的难点依旧是去重,但是与之前做过的子集类问题的区别就是,这里是求子序列,意味着我们不能先给数组中的元素排序。因为子序列中的元素的相对位置跟原数组中的相对位置是一样的,如果我们改变数组中元素的顺序,子序列也会发生改变。那么我们就不能使用之前用到过的去重方法,此题需要使用道哈希表,这样就可以实现去重的功能。哈希表的使用我们之前也练过不少题,这里就不详细说明了,忘记的同学可以看一下之前的博客。需要注意的是,我们需要在每一层递归中都定义一个新的哈希表,原因在于:往下递归子序列可以取重复的元素,但是在同一层递归的for循环中遍历时需要跳过重复的元素。其他的点比较好懂,大家可以结合我下面的代码及详细注释理解此题。

代码及详细注释如下:

class Solution {
public:vector<int> path;vector<vector<int>> result;void backtracking(vector<int>& nums,int start){//注意题目说了至少两个元素if(path.size() >= 2){result.push_back(path);}    //终止条件if(start >= nums.size()){return;}//每一层递归都需要定义一个新的哈希表unordered_set<int> uset;for(int i = start;i < nums.size();i++){//去重操作if((path.empty() != 1 && nums[i] < path.back()) || uset.find(nums[i]) != uset.end()){continue;}uset.insert(nums[i]);path.push_back(nums[i]);backtracking(nums,i + 1);path.pop_back();//注意哈希表并不需要回溯,因为每一层都有专门的哈希表来负责去重}}vector<vector<int>> findSubsequences(vector<int>& nums) {result.clear();path.clear();backtracking(nums,0);return result;}
};

http://www.15wanjia.com/news/163487.html

相关文章:

  • 做saas平台网站html5教程视频教程
  • 想做网站360网站图标怎么做
  • 2015百度竞价单页面网站模板源码设计广告投放软件
  • wordpress图片上传大小东莞市seo网络推广服务机构
  • 专业网站设计建设服务wordpress版权修改文件
  • 网站申请微信登录免费空间说说点赞
  • 世纪佳缘网站开发公司婚介 东莞网站建设
  • 网站设计需要哪些技术深圳住房与建设局官网
  • 建设网站后怎么发布淘宝软件营销网站建设
  • 网站下面的站长统计很逗手机网站建设推荐
  • 帮传销做网站做网站项目计划书
  • 制作企业网站的版式wordpress 响应式产品展示站
  • 织梦手机网站有广告位域名备案信息查询官网
  • 廊坊网站制作建在线教育网站需要多少钱
  • 上海一家做服饰包鞋穿上用品的网站云南省网站建设收费调查报告论文
  • 宁波优化网站排名软件做音乐的网站
  • 微网站制作网站开发现在网络推广哪家好
  • 标书制作教程视频网站wordpress twilight saga 主题
  • 建设网站的市场环境怎么样网创是什么
  • 昆明网站建设云集创怎么做系部网站首页
  • 有哪些做公司网站的南通专业网站排名推广
  • 阿里云做网站需要些什么模板网站和插件
  • 网站建设费要摊销网络工程就业方向及就业前景
  • 上海免费推广网站有哪些阿里巴巴网站建设基础服务
  • 河北华宇建设集团有限公司网站wordpress恢复备份数据库
  • 深圳勘察设计协会新乡优化
  • 成都网站系统开发电商设计包括什么
  • 门户网站开发难点wordpress 下载按钮插件
  • 深圳建网站的公司朗润装饰成都装修公司官网
  • 模板建站和定制建站室内设计师联盟app