求问有什么站立式办公桌推荐?

一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
H1B/绿卡遥遥无期
又不想回国
来东南亚最大的互联网集团工作?
码农求职神器Triplebyte:
不用海投
内推多家公司面试
坐标湾区
Games Startup
招聘游戏开发工程师
游戏初创公司招聘工程师、UIUX Designer和游戏策划
查看: 362|回复: 3
收起左侧

[Leetcode] 关于Subsets中deep copy的问题

[复制链接] |试试Instant~ |关注本帖
我的人缘0
yayugk 发表于 2017-10-31 08:22:11 | 显示全部楼层 |阅读模式
  此人我要顶:
 
0% (暂未有人投票) 【我投】
  此人我要踩:
 
0% (暂未有人投票) 【我投】

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?Sign Up 注册获取更多干货

x
本帖最后由 yayugk 于 2017-10-31 10:36 编辑

请问下为什么第一个需要deep copy
第二个不需要deep copy呢
谢谢!

                               
登录/注册后可看大图
  1. private void helper(ArrayList<Integer> subset,
  2.                         int[] nums,
  3.                         int startIndex,
  4.                         List<List<Integer>> results) {
  5.         // 2. 递归的拆解
  6.         // deep copy
  7.         // results.add(subset);
  8.         results.add(new ArrayList<Integer>(subset))

  9.         for (int i = startIndex; i < nums.length; i++) {
  10.             subset.add(nums[i]);
  11.             helper(subset, nums, i + 1, results);
  12.             subset.remove(subset.size() - 1);
  13.         }
  14.         

  15.         // return;
  16.     }
复制代码
  1.     public List<List<Integer>> subsets(int[] nums) {
  2.         List<List<Integer>> result = new ArrayList<List<Integer>>();
  3.         int n = nums.length;
  4.         Arrays.sort(nums);
  5.         

  6.         for (int i = 0; i < (1 << n); i++) {
  7.             List<Integer> subset = new ArrayList<Integer>();
  8.             for (int j = 0; j < n; j++) {
  9.                 // check whether the jth digit in i's binary representation is 1
  10.                 if ((i & (1 << j)) != 0) {
  11.                     subset.add(nums[j]);
  12.                 }
  13.             }
  14.             //deep copy
  15.             result.add(subset);
  16.         }
  17.         return result;
  18.     }
复制代码

上一篇:请问有人用python AC leetcode149题么?求答案
下一篇:买卖股票的这几道题很有意思
我的人缘0
 楼主| yayugk 发表于 2017-11-2 03:46:27 | 显示全部楼层
  此人我要顶:
 
0% (暂未有人投票) 【我投】
  此人我要踩:
 
0% (暂未有人投票) 【我投】
就是为什么第二个不使用deep copy也能把数据加到res里面去呢?
回复 支持 反对

使用道具 举报

全球28万学生4.7分推荐
我的人缘0
sonicgu 发表于 2017-11-4 14:30:21 | 显示全部楼层
  此人我要顶:
 
0% (暂未有人投票) 【我投】
  此人我要踩:
 
0% (暂未有人投票) 【我投】
第二个每次都会重新new 一个arraylist
回复 支持 反对

使用道具 举报

我的人缘0
zhouhao 发表于 2017-11-4 23:42:37 | 显示全部楼层
  此人我要顶:
 
0% (暂未有人投票) 【我投】
  此人我要踩:
 
0% (暂未有人投票) 【我投】
yayugk 发表于 2017-11-1 15:46
就是为什么第二个不使用deep copy也能把数据加到res里面去呢?

第二个在第八行new了。第二个方法有限制的,如果nums.length超过了Integer的位数就不好使了。但是作为位运算,那个方法还是比较秒的
回复 支持 反对

使用道具 举报

游客
请先登录

本版积分规则

提醒:发帖可以选择内容隐藏,部分板块支持匿名发帖。请认真读完以下全部说明:

■隐藏内容方法: [hide=200]你想要隐藏的内容比如面经[/hide]
■意思是:用户积分低于200则看不到被隐藏的内容
■可以自行设置积分值,不建议太高(200以上太多人看不到),也不建议太低(那就没必要隐藏了)
■建议只隐藏关键内容,比如具体的面试题目、涉及隐私的信息,大部分内容没必要隐藏。
■微信/QQ/电子邮件等,为防止将来被骚扰甚至人肉,以论坛私信方式发给对方最安全。
■匿名发帖的板块和方法:http://www.1point3acres.com/bbs/thread-405991-1-1.html

关闭

一亩三分地推荐上一条 /3 下一条

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2018-6-18 21:39

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表