亚麻OA求砸,面经神衣护体!


一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
天天打游戏、照样领工资、还办H1B
这份工作你要不要?
把贵司招聘信息放这里
查看: 4518|回复: 22
收起左侧

Uber电面-4sum

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

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

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

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

x
今天uber电面. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
问了三年规划5年目标...(`_′)ゞ

幸运地考到4sum...leetcode原题. visit 1point3acres.com for more.
不幸运地,我之前的解法都是n^3.但今天要我写出n^2的代码。
没来得及把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;
  12.                         return true;
  13.                 }
  14. . From 1point 3acres bbs
  15.                 public int hashCode() {
  16.                         Integer ans = 2;
  17.                         for (int i : eles) {
  18.                                 ans += ans * i;
  19.                         } 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  20.                         return ans;
  21.                 }

  22.                 public boolean equals(Object that) {. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  23.                         if (!(that instanceof Pair))
  24.                                 return false;. 鍥磋鎴戜滑@1point 3 acres
  25.                         if (that == this)-google 1point3acres
  26.                                 return true;
  27.                         for (int i = 0; i < 4; i++) {
  28.                                 if (this.eles[i] != ((Pair) that).eles[i]). visit 1point3acres.com for more.
  29.                                         return false;
  30.                         }.鐣欏璁哄潧-涓浜-涓夊垎鍦

  31.                         return true;
  32.                 }

  33.         }

  34.         public static List<List<Integer>> sum4(List<Integer> list, int target) {
  35.                 Collections.sort(list);
  36.                 List<List<Integer>> ans = new ArrayList<List<Integer>>();
    . 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴

  37.                 // Map <2sum, list of pairs>
  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);. 1point3acres.com/bbs
  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);
  51.                                 }
  52.                         }
  53.                 }
  54. 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  55.                 Set<Pair> set = new HashSet<Pair>();
  56.                 for (int key : map.keySet()) {
  57.                         int anotherkey = target - key;
  58.                         if (anotherkey < key)
  59.                                 continue;. visit 1point3acres.com for more.
  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);
  67.                                                 if (Pair.valid(a, b, c, d)) {. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  68.                                                         Pair pair = new Pair(a, b, c, d);. 1point 3acres 璁哄潧
  69.                                                         set.add(pair);
  70. .鐣欏璁哄潧-涓浜-涓夊垎鍦
  71.                                                 }

  72.                                         }. From 1point 3acres bbs

  73.                                 }

  74.                         }
  75.                 }

  76.                 for (Pair p : set) {. more info on 1point3acres.com
  77.                         List<Integer> path = new ArrayList<Integer>();. from: 1point3acres.com/bbs
  78.                         for (Integer ele : p.eles) {
  79.                                 path.add(list.get(ele));
  80.                         }
  81.                         ans.add(path);
  82.                 }.1point3acres缃
  83.                 return ans;
  84.         }

  85. . visit 1point3acres.com for more.
  86.         public static void main(String[] args) {
  87.                 ArrayList<String> strings = new ArrayList<String>();. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  88.                 Integer[] numbers = new Integer[] { 4, 2, 6, 1, 5, 3 };
  89.                 List<Integer> list = Arrays.asList(numbers);
  90.                 System.out.println(sum4(list, 16));. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷

  91.         }
  92. }
复制代码

评分

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
  .鏈枃鍘熷垱鑷1point3acres璁哄潧
    参数要求: 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
骑驴找马

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

使用道具 举报

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. visit 1point3acres.com for more.
嗯...worst case可能要n^4了...
. 鍥磋鎴戜滑@1point 3 acres
worst case 也不应该 是 n^4.... 吧. From 1point 3acres bbs
应该 是 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)

这不是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
. 鍥磋鎴戜滑@1point 3 acres
嗯  是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-10-21 02:08

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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