一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 2565|回复: 22
收起左侧

Uber电面-4sum

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

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

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

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

x
今天uber电面
问了三年规划5年目标...(`_′)ゞ

幸运地考到4sum...leetcode原题
不幸运地,我之前的解法都是n^3.但今天要我写出n^2的代码。. 1point 3acres 璁哄潧
没来得及把bug调完 ....sad

贴一记后来反省写完的代码....
  1. class Solution {. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  2.         // store index of pair
  3.         static class Pair {
  4.                 Integer[] eles;

  5.                 public Pair(int a, int b, int c, int d) {
  6.                         eles = new Integer[] { a, b, c, d };
  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;. 1point 3acres 璁哄潧
  12.                         return true;
  13.                 }

  14.                 public int hashCode() {
  15.                         Integer ans = 2;. From 1point 3acres bbs
  16.                         for (int i : eles) {
  17.                                 ans += ans * i;
  18.                         }
  19.                         return ans;
  20.                 }

  21.                 public boolean equals(Object that) {
  22.                         if (!(that instanceof Pair))
  23.                                 return false;
  24.                         if (that == this)
  25.                                 return true;. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  26.                         for (int i = 0; i < 4; i++) {
  27.                                 if (this.eles[i] != ((Pair) that).eles[i])
  28.                                         return false;
  29.                         }

  30.                         return true;
  31.                 }

  32.         }

  33.         public static List<List<Integer>> sum4(List<Integer> list, int target) {. 鍥磋鎴戜滑@1point 3 acres
  34.                 Collections.sort(list);
  35.                 List<List<Integer>> ans = new ArrayList<List<Integer>>();
  36. . from: 1point3acres.com/bbs
  37.                 // Map <2sum, list of pairs>. 1point3acres.com/bbs
  38.                 Map<Integer, List<List<Integer>>> map = new HashMap<Integer, List<List<Integer>>>();

  39.                 for (int i = 0; i < list.size(); i++) {
  40.                         for (int j = i + 1; j < list.size(); j++) {
  41.                                 int sum2 = list.get(i) + list.get(j);
  42.                                 List<Integer> pair = new ArrayList<Integer>();
  43.                                 pair.add(i);
  44.                                 pair.add(j);
  45.                                 if (map.containsKey(sum2)) {
  46.                                         map.get(sum2).add(pair);
  47.                                 } else {
  48.                                         List<List<Integer>> listofPair = new ArrayList<List<Integer>>();
  49.                                         listofPair.add(pair);
  50.                                         map.put(sum2, listofPair);. 1point3acres.com/bbs
  51.                                 }
  52.                         }
  53.                 }

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

  72.                                         }. 鍥磋鎴戜滑@1point 3 acres
  73. . 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  74.                                 }
  75. . 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  76.                         }
  77.                 }. visit 1point3acres.com for more.

  78.                 for (Pair p : set) {
  79.                         List<Integer> path = new ArrayList<Integer>();
  80.                         for (Integer ele : p.eles) {
  81.                                 path.add(list.get(ele));
  82.                         }
  83.                         ans.add(path);
  84.                 }
  85.                 return ans;
  86.         }
  87. . 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  88.         public static void main(String[] args) {
  89.                 ArrayList<String> strings = new ArrayList<String>();
  90.                 Integer[] numbers = new Integer[] { 4, 2, 6, 1, 5, 3 };. from: 1point3acres.com/bbs
  91.                 List<Integer> list = Arrays.asList(numbers);
  92.                 System.out.println(sum4(list, 16));

  93.         }
  94. }
复制代码

评分

4

查看全部评分

本帖被以下淘专辑推荐:

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

使用道具 举报

 楼主| jaly50 发表于 2015-8-29 11:28:16 | 显示全部楼层
bluezebra 发表于 2015-8-29 11:09
这么良心的帖子没人顶?感谢楼主!

应该加分 XD

. 鍥磋鎴戜滑@1point 3 acres
拿到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.. from: 1point3acres.com/bbs
2. a + b + c + d = target.鏈枃鍘熷垱鑷1point3acres璁哄潧
3. a <= b <= c <= d. from: 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. from: 1point3acres.com/bbs
骑驴找马
回复 支持 反对

使用道具 举报

whdawn 发表于 2015-8-29 13:22:56 | 显示全部楼层
jaly50 发表于 2015-8-29 13:10
不是学长. 鍥磋鎴戜滑@1point 3 acres
不等TOC.鐣欏璁哄潧-涓浜-涓夊垎鍦
骑驴找马

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

使用道具 举报

larry_cn 发表于 2015-8-29 13:36:07 | 显示全部楼层
jaly50 发表于 2015-8-29 11:28-google 1point3acres
应该加分 XD

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

使用道具 举报

larry_cn 发表于 2015-8-29 13:41:39 | 显示全部楼层
jaly50 发表于 2015-8-29 13:10
. Waral 鍗氬鏈夋洿澶氭枃绔,嗯...worst case可能要n^4了...

worst case 也不应该 是 n^4.... 吧. more info on 1point3acres.com
应该 是 n^3
回复 支持 反对

使用道具 举报

 楼主| jaly50 发表于 2015-8-30 06:41:40 | 显示全部楼层
larry_cn 发表于 2015-8-29 13:41. 鍥磋鎴戜滑@1point 3 acres
worst case 也不应该 是 n^4.... 吧
应该 是 n^3
. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
假设n个数都是1, target是4.
这样子 map里就只有 key=2; Value中list.size=n*(n+1)/2


所以下面的循环中  
(key:map.keySet()) //o(1)
for (firstValues:map.get(key))  // o(n^2)
for (secondValues: map.get(anotherkey) )// o(n^2)

这不是n^4么. from: 1point3acres.com/bbs
回复 支持 反对

使用道具 举报

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 这个 地方 额 没考虑对. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷

(不过楼主 那个 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 :
1. {5,5,5,5} 20
2. { 4, 2, 6, 1, 5, 3, 0,4,0 } 16
回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

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

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

custom counter

GMT+8, 2016-12-4 01:51

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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