一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
码农求职神器Triplebyte:
不用海投,内推你去多家公司面试
Airbnb 数据科学职位
in analytics and inference
天天打游戏、照样领工资,
你要不要来?
把贵司招聘信息放这里
查看: 4624|回复: 22
收起左侧

Uber电面-4sum

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

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

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

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

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

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

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

  5. . visit 1point3acres.com for more.
  6.                 public Pair(int a, int b, int c, int d) {. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  7.                         eles = new Integer[] { a, b, c, d };.1point3acres缃
  8.                         Arrays.sort(eles);
  9.                 }
  10. . more info on 1point3acres.com
  11.                 static boolean valid(int a, int b, int c, int d) {. visit 1point3acres.com for more.
  12.                         if (a == c || b == d || b == c)
  13.                                 return false;
  14.                         return true;
  15.                 }
  16. -google 1point3acres
  17.                 public int hashCode() {
  18.                         Integer ans = 2;
  19.                         for (int i : eles) {
  20.                                 ans += ans * i;
  21.                         }
  22.                         return ans;
  23.                 }

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

  33.                         return true;
  34.                 }

  35.         }

  36.         public static List<List<Integer>> sum4(List<Integer> list, int target) {
  37.                 Collections.sort(list);. 鍥磋鎴戜滑@1point 3 acres
  38.                 List<List<Integer>> ans = new ArrayList<List<Integer>>();

  39.                 // Map <2sum, list of pairs>
  40.                 Map<Integer, List<List<Integer>>> map = new HashMap<Integer, List<List<Integer>>>();. more info on 1point3acres.com

  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);. 1point3acres.com/bbs
  52.                                         map.put(sum2, listofPair);
  53.                                 }
  54.                         }
  55.                 }
  56. . more info on 1point3acres.com
  57.                 Set<Pair> set = new HashSet<Pair>();
  58.                 for (int key : map.keySet()) {
  59.                         int anotherkey = target - key;
  60.                         if (anotherkey < key)
  61.                                 continue;
  62.                         if (map.containsKey(anotherkey)) {
  63.                                 for (List<Integer> firstValues : map.get(key)) {
  64.                                         int a = firstValues.get(0);
  65.                                         int b = firstValues.get(1);
  66.                                         for (List<Integer> secondValues : map.get(anotherkey)) {
  67.                                                 int c = secondValues.get(0);
  68.                                                 int d = secondValues.get(1);
  69.                                                 if (Pair.valid(a, b, c, d)) {
  70.                                                         Pair pair = new Pair(a, b, c, d);. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  71.                                                         set.add(pair);

  72.                                                 }
  73. . 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  74.                                         }
    . 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴

  75.                                 }

  76.                         }
  77.                 }
  78. . 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  79.                 for (Pair p : set) {
  80.                         List<Integer> path = new ArrayList<Integer>();
  81.                         for (Integer ele : p.eles) {
  82.                                 path.add(list.get(ele));
  83.                         }
  84.                         ans.add(path);
  85.                 }
  86.                 return ans;
  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 };
  91.                 List<Integer> list = Arrays.asList(numbers);
  92.                 System.out.println(sum4(list, 16));.1point3acres缃

  93.         }.1point3acres缃
  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


拿到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
  
. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷    参数要求: 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会很长
. Waral 鍗氬鏈夋洿澶氭枃绔,
嗯...worst case可能要n^4了...
回复 支持 反对

使用道具 举报

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

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

使用道具 举报

whdawn 发表于 2015-8-29 13:22:56 | 显示全部楼层
jaly50 发表于 2015-8-29 13:10
不是学长
不等TOC
骑驴找马

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

使用道具 举报

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


所以下面的循环中  
(key:map.keySet()) //o(1)
for (firstValues:map.get(key))  // o(n^2)
for (secondValues: map.get(anotherkey) )// o(n^2)-google 1point3acres
鏉ユ簮涓浜.涓夊垎鍦拌鍧.
这不是n^4么. more info on 1point3acres.com
回复 支持 反对

使用道具 举报

larry_cn 发表于 2015-8-30 09:55:12 | 显示全部楼层
jaly50 发表于 2015-8-30 06:41. Waral 鍗氬鏈夋洿澶氭枃绔,
假设n个数都是1, target是4. 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
这样子 map里就只有 key=2; Value中list.size=n*(n+1)/2

嗯  是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
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

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

custom counter

GMT+8, 2017-12-15 14:24

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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