May 2009 - May 2017 论坛八周年-你的足迹,我的骄傲


一亩三分地论坛

 找回密码
 获取更多干活,快来注册

一亩三分地官方iOS手机应用下载
查看: 3997|回复: 22
收起左侧

Uber电面-4sum

[复制链接] |试试Instant~ |关注本帖
jaly50 发表于 2015-8-28 13:08:39 | 显示全部楼层 |阅读模式

2015(7-9月) 码农类 硕士 全职@Uber - 内推 - 技术电面 |Otherfresh grad应届毕业生

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

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

x
今天uber电面
问了三年规划5年目标...(`_′)ゞ
. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
幸运地考到4sum...leetcode原题
不幸运地,我之前的解法都是n^3.但今天要我写出n^2的代码。. 鍥磋鎴戜滑@1point 3 acres
没来得及把bug调完 ....sad

贴一记后来反省写完的代码....
  1. class Solution {
  2.         // store index of pair
  3.         static class Pair {
  4.                 Integer[] eles;. 1point3acres.com/bbs

  5.                 public Pair(int a, int b, int c, int d) {
  6.                         eles = new Integer[] { a, b, c, d };. 1point3acres.com/bbs
  7.                         Arrays.sort(eles);
  8.                 }

  9.                 static boolean valid(int a, int b, int c, int d) {
  10.                         if (a == c || b == d || b == c)
  11.                                 return false;
  12.                         return true;
  13.                 }

  14.                 public int hashCode() {
  15.                         Integer ans = 2;
  16.                         for (int i : eles) {
  17.                                 ans += ans * i;
  18.                         }
  19.                         return ans;
  20.                 }-google 1point3acres
  21. . from: 1point3acres.com/bbs
  22.                 public boolean equals(Object that) {
  23.                         if (!(that instanceof Pair)).鐣欏璁哄潧-涓浜-涓夊垎鍦
  24.                                 return false;
  25.                         if (that == this)
  26.                                 return true;
  27.                         for (int i = 0; i < 4; i++) {
  28.                                 if (this.eles[i] != ((Pair) that).eles[i]).鏈枃鍘熷垱鑷1point3acres璁哄潧
  29.                                         return false;
  30.                         }
  31. . 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  32.                         return true;. 鍥磋鎴戜滑@1point 3 acres
  33.                 }

  34.         }.鏈枃鍘熷垱鑷1point3acres璁哄潧
  35. . 1point3acres.com/bbs
  36.         public static List<List<Integer>> sum4(List<Integer> list, int target) {
  37.                 Collections.sort(list);
  38.                 List<List<Integer>> ans = new ArrayList<List<Integer>>();. 鍥磋鎴戜滑@1point 3 acres

  39.                 // Map <2sum, list of pairs>
  40.                 Map<Integer, List<List<Integer>>> map = new HashMap<Integer, List<List<Integer>>>();

  41.                 for (int i = 0; i < list.size(); i++) {. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  42.                         for (int j = i + 1; j < list.size(); j++) {
  43.                                 int sum2 = list.get(i) + list.get(j);
  44.                                 List<Integer> pair = new ArrayList<Integer>();
  45.                                 pair.add(i);
  46.                                 pair.add(j);
  47.                                 if (map.containsKey(sum2)) {
  48.                                         map.get(sum2).add(pair);
  49.                                 } else {
  50.                                         List<List<Integer>> listofPair = new ArrayList<List<Integer>>();
  51.                                         listofPair.add(pair);
  52.                                         map.put(sum2, listofPair);
  53.                                 }
  54.                         }
  55.                 }

  56.                 Set<Pair> set = new HashSet<Pair>();
  57.                 for (int key : map.keySet()) {
  58.                         int anotherkey = target - key;. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  59.                         if (anotherkey < key)
  60.                                 continue;
  61.                         if (map.containsKey(anotherkey)) {
  62.                                 for (List<Integer> firstValues : map.get(key)) {
  63.                                         int a = firstValues.get(0);
  64.                                         int b = firstValues.get(1);
  65.                                         for (List<Integer> secondValues : map.get(anotherkey)) {
  66.                                                 int c = secondValues.get(0);
  67.                                                 int d = secondValues.get(1);. visit 1point3acres.com for more.
  68.                                                 if (Pair.valid(a, b, c, d)) {
  69.                                                         Pair pair = new Pair(a, b, c, d);.1point3acres缃
  70.                                                         set.add(pair);. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  71. -google 1point3acres
  72.                                                 }

  73.                                         }. visit 1point3acres.com for more.
  74. . 1point 3acres 璁哄潧
  75.                                 }

  76.                         }
  77.                 }

  78.                 for (Pair p : set) {
  79.                         List<Integer> path = new ArrayList<Integer>();. 1point3acres.com/bbs
  80.                         for (Integer ele : p.eles) {
  81.                                 path.add(list.get(ele));
  82.                         }. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  83.                         ans.add(path);
  84.                 }. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  85.                 return ans;
  86.         }
  87. .鏈枃鍘熷垱鑷1point3acres璁哄潧
  88.         public static void main(String[] args) {.1point3acres缃
  89.                 ArrayList<String> strings = new ArrayList<String>();
  90.                 Integer[] numbers = new Integer[] { 4, 2, 6, 1, 5, 3 };
  91.                 List<Integer> list = Arrays.asList(numbers);
  92.                 System.out.println(sum4(list, 16));
  93. . 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  94.         }
  95. }
复制代码

评分

4

查看全部评分

本帖被以下淘专辑推荐:

likenisha 发表于 2015-11-29 06:02:40 | 显示全部楼层
关注一亩三分地公众号:
Warald_一亩三分地
我怎么觉得这个代码不是很对。。。。比如{1,2,3}, pair会是{1,2}{2,3}{1,3},但很明显这个array是没结果的,可是pair可能target等于7的时候有一个输出,似乎不太对
回复 支持 1 反对 0

使用道具 举报

 楼主| jaly50 发表于 2015-8-29 11:28:16 | 显示全部楼层
关注一亩三分地微博:
Warald
bluezebra 发表于 2015-8-29 11:09
这么良心的帖子没人顶?感谢楼主!

应该加分 XD


拿到onsite了 :)
回复 支持 0 反对 1

使用道具 举报

 楼主| jaly50 发表于 2015-8-28 13:22:02 | 显示全部楼层
Give a array of integers, find all unique 4 number combination (a, b, c, d) that satisfy:
1. a, b, c and d is in the array and each element in the array can be used only once.
2. a + b + c + d = target
3. a <= b <= c <= d
  . 1point3acres.com/bbs
    参数要求: public  List<List<Integer>> sum4(List<Integer> list, int target) {}
回复 支持 反对

使用道具 举报

bluezebra 发表于 2015-8-29 11:09:05 | 显示全部楼层
这么良心的帖子没人顶?感谢楼主!
回复 支持 反对

使用道具 举报

jy_121 发表于 2015-8-29 11:45:34 | 显示全部楼层
恭喜楼主,好像之前跟CS61B的时候见过你的帖子。从O(n3)到O(n2)就是将一层的遍历换成hashmap吗
回复 支持 反对

使用道具 举报

wenqiang88 发表于 2015-8-29 11:52:49 | 显示全部楼层
如果array里面有重复元素的话,那么worst case 不止O(n^2)吧,因为map里的list会很长
回复 支持 反对

使用道具 举报

whdawn 发表于 2015-8-29 11:59:12 | 显示全部楼层
学长还在匹村等TOC吗~
回复 支持 反对

使用道具 举报

 楼主| jaly50 发表于 2015-8-29 13:10:00 | 显示全部楼层
wenqiang88 发表于 2015-8-29 11:52
如果array里面有重复元素的话,那么worst case 不止O(n^2)吧,因为map里的list会很长

嗯...worst case可能要n^4了...
回复 支持 反对

使用道具 举报

 楼主| jaly50 发表于 2015-8-29 13:10:36 | 显示全部楼层
whdawn 发表于 2015-8-29 11:59
学长还在匹村等TOC吗~

不是学长
不等TOC
骑驴找马
回复 支持 反对

使用道具 举报

whdawn 发表于 2015-8-29 13:22:56 | 显示全部楼层
jaly50 发表于 2015-8-29 13:10
不是学长 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
不等TOC. 1point3acres.com/bbs
骑驴找马

那就是学姐了。。。我错了
回复 支持 反对

使用道具 举报

larry_cn 发表于 2015-8-29 13:36:07 | 显示全部楼层

然而 楼主 没有说明 n^2 在哪里
也没有 看出来 代码 是 n^2
回复 支持 反对

使用道具 举报

larry_cn 发表于 2015-8-29 13:41:39 | 显示全部楼层
jaly50 发表于 2015-8-29 13:10
嗯...worst case可能要n^4了...

worst case 也不应该 是 n^4.... 吧
应该 是 n^3
回复 支持 反对

使用道具 举报

 楼主| jaly50 发表于 2015-8-30 06:41:40 | 显示全部楼层
larry_cn 发表于 2015-8-29 13:41
worst case 也不应该 是 n^4.... 吧
应该 是 n^3

假设n个数都是1, target是4.
这样子 map里就只有 key=2; Value中list.size=n*(n+1)/2. 鍥磋鎴戜滑@1point 3 acres
. more info on 1point3acres.com

所以下面的循环中  
(key:map.keySet()) //o(1)
for (firstValues:map.get(key))  // o(n^2). more info on 1point3acres.com
for (secondValues: map.get(anotherkey) )// o(n^2)
-google 1point3acres
这不是n^4么. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
回复 支持 反对

使用道具 举报

larry_cn 发表于 2015-8-30 09:55:12 | 显示全部楼层
jaly50 发表于 2015-8-30 06:41
假设n个数都是1, target是4.
这样子 map里就只有 key=2; Value中list.size=n*(n+1)/2
. from: 1point3acres.com/bbs
嗯  是n^4 这个 地方 额 没考虑对. more info on 1point3acres.com

(不过楼主 那个 size 和 little-O 用错了)
回复 支持 反对

使用道具 举报

hulahu 发表于 2015-8-30 11:07:44 | 显示全部楼层
楼主, 下次打给答案, 照抄。 好难哦。。
回复 支持 反对

使用道具 举报

会编程的猪先生 发表于 2015-9-4 06:24:18 | 显示全部楼层
所以worst case是O(n^4) 根据楼主面试情况 这是面试官想要的答案吗?
回复 支持 反对

使用道具 举报

mary小丸子 发表于 2015-9-4 06:55:42 | 显示全部楼层
楼主你好。我是CMU 14 FaLL ECE的。顶楼主。也要电面了。
回复 支持 反对

使用道具 举报

aplusplus 发表于 2015-9-13 06:24:03 | 显示全部楼层
这题不可能< O(n^3)的ba
回复 支持 反对

使用道具 举报

f1371342385 发表于 2015-9-18 07:25:04 | 显示全部楼层
LZ,你的这个方法就是存下标啊 然后找出来以后得到4 sum的解啊
回复 支持 反对

使用道具 举报

jypdw 发表于 2015-10-19 07:03:06 | 显示全部楼层
LZ, 算法有点问题吧?
test case :
.1point3acres缃1. {5,5,5,5} 20
2. { 4, 2, 6, 1, 5, 3, 0,4,0 } 16
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2017-5-28 07:48

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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