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

美发网站怎么做齐齐哈尔住房和城乡建设局网站

美发网站怎么做,齐齐哈尔住房和城乡建设局网站,网站建设公司市场,贵州建设厅网站政务大厅这道题如果用暴力法几乎是不可能解出来的&#xff0c;因为情况太复杂了&#xff0c;但是一旦用上递归回溯就会轻松很多&#xff0c;先上代码&#xff1a; class Solution {List<List<Integer>> result new ArrayList<List<Integer>>();List<Integ…

 这道题如果用暴力法几乎是不可能解出来的,因为情况太复杂了,但是一旦用上递归回溯就会轻松很多,先上代码:

class Solution {List<List<Integer>> result = new ArrayList<List<Integer>>();List<Integer> list = new ArrayList<Integer>();public List<List<Integer>> subsets(int[] nums) {dfs(0,nums);return result;}public void dfs(int cur, int[] nums){if(cur == nums.length){result.add(new ArrayList<Integer>(list));return;}list.add(nums[cur]);dfs(cur+1, nums);list.remove(list.size()-1);dfs(cur+1, nums);}
}

对于数组中每个元素,其无非就两种状态,加入这个数组或者不加入这个数组,所以我们创建一个递归方法dfs(int cur, int[] nums),cur就是我们当前处理的这个元素的下标。

if(cur == nums.length){result.add(new ArrayList<Integer>(list));return;}

如果这个下标等于数组长度,说明数组中的所有元素都判断过了,可以把这个数组放进答案里了,但是我们不能把list放进去,因为这个list是全局的,dfs方法都在动这个list,后面的dfs会修改list,如果是放list,那么result里面就是全部一样的list并且是最后改完的list也就是空的list,因为最后一个递归是所有元素都是不添加的情况。所以这里用的是result.add(new ArrayList<Integer>(list));把list的副本添加进了result,这个副本不是指向list而是一个新的对象通过这个new也可以看出。

添加nums[cur]的情况:

list.add(nums[cur]);
dfs(cur+1, nums);

不添加nums[cur]的情况:

 list.remove(list.size()-1);dfs(cur+1, nums);

nums[cur]的情况判断完了,后面dfs(cur+1,nums)判断nums[cur+1]的情况。

还有一种方法是迭代法

class Solution {List<List<Integer>> result = new ArrayList<List<Integer>>();List<Integer> list = new ArrayList<Integer>();public List<List<Integer>> subsets(int[] nums) {int n = nums.length;for(int mask =0;mask < Math.pow(2,n);++mask){list.clear();for(int i = 0;i<n;i++){if((mask & (1 << i)) != 0){list.add(nums[i]);}}result.add(new ArrayList<Integer>(list));}return result;}
}

就用对于数组中的任一元素用0,1表示它的状态,0表示不在数组中,1表示在数组中。假设数组长度为n,那么每一个n位的的01序列都表示一种情况,一共有2的n次方个序列,分别是0到2的n次方减1,那么我们只需要每一种情况都用一个list放数据就好了,对于每一个list我们需要遍历这n位,如果第i位是1就把nums[i]放进list,0则不放。

那么如何判断第i位是0还是1呢?只需要和一个第i位是1其他位是0的数按位与即可。

比如,10101 & 00100,就是00100,10001 & 00100,就是00000,它是把每一位的分别进行与,与的结果作为最终结果的第i位。所以用1左移i位就会得到一个只有第i位是1其他位是0的数,我们那么与的结果就取决于mask的第i位,如果第i位是0,那么每一位与的结果都是0,最终结果是0;如果第i位是1与的结果就是第i位是1其他位是0的数,这样就可以判断第i位是0还是1了。

http://www.yayakq.cn/news/409403/

相关文章:

  • 制作一个公司网站用vs怎么做湘潭自适应网站建设 磐石网络
  • 安徽白云集团网站建设分销渠道系统
  • 企业网站模板下载哪家口碑好论文收录网站排名
  • 商标与logo的区别seo网站排名优化公司
  • 网站建设在哪里找人培训课程有哪些
  • 网站开发技术要求耀华建设管理有限公司网站
  • 做网站就是做点击率佛山新网站建设哪家好
  • 三九集团如何进行网站建设苏州网页设计app
  • 网站构建的过程软件开发公司服务
  • 济南免费网站建站模板负责网站建设和网络推广的
  • 网站建设大概要多少钱广州建筑工程公司名单
  • 做网站域名服务器千锋教育培训怎么样
  • 台州专业做网站做公司网站的总结
  • 免费分类信息网站大全照片书哪个网站做的好
  • 新干做网站如何用vs2012做网站
  • 网站开发岗位群海南省建设网站
  • 婚纱摄影网站建设广州网络科技有限公司
  • 网站遭到攻击绍兴专门做网站
  • 加工平台网站舒肤佳网络营销方案
  • iis如何做网站管理器乌镇网站建设投标书
  • 做英语手抄报 什么网站网站图片倒计时怎么做的
  • 网站设计要多久东莞百度代做网站联系方式
  • 苏州网站建设网站制作的公司网站建设的网站分析怎么写
  • 网站整合建设是啥意思营销软件app
  • 网站设计规划的目的和要求个人网站建设挂载下载链接
  • 青海设计网站如何做介绍监控公司的网站
  • 网站建设样本php网站开发程序编译软件
  • 小型网站项目策划书优质的聊城做网站
  • 域名不变修改网站怎么做wordpress输出响应式图片大小
  • 丽水企业网站建设公司吴川网站开发公司