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


一亩三分地论坛

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

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

[找工就业] Google电面面经

[复制链接] |试试Instant~ |关注本帖
alikewmk 发表于 2015-11-14 05:50:48 | 显示全部楼层 |阅读模式

2015(10-12月)-[14]CS硕士+1-3年 - Other| 码农类全职@Googlefresh grad应届毕业生

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

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

x
刚面完,两题:

第一题:. visit 1point3acres.com for more.

. visit 1point3acres.com for more.给一个西班牙语的字母表,多了一个ch
a b c ch d...
然后要求按照给的字母表排序单词。
. From 1point 3acres bbs

解法:递归compare, 在compare的时候先解决特殊情况,然后其他跟英语一样. 1point 3acres 璁哄潧
. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
第二题:.鐣欏璁哄潧-涓浜-涓夊垎鍦
长短链接转换

解法:楼主用的HashMap,提了下MD5不过没有实现,忘了问面试官用不用实现了...
然后要求是长的可以转短的,短的也得能转长的,楼主只实现了前一部分,后面的正在想时间到了。
希望可以onsite啊... . 1point 3acres 璁哄潧
杰西Jesse 发表于 2015-11-14 10:42:31 | 显示全部楼层
关注一亩三分地公众号:
Warald_一亩三分地
第一题可以用comparator<String, String> 么?. from: 1point3acres.com/bbs
所以是有一个hashcode(string) -> shortened url?
hash (key: short url, value: long url)
回复 支持 反对

使用道具 举报

 楼主| alikewmk 发表于 2015-11-14 14:24:53 | 显示全部楼层
关注一亩三分地微博:
Warald
杰西Jesse 发表于 2015-11-14 10:42
第一题可以用comparator 么?
所以是有一个hashcode(string) -> shortened url?
hash (key: short url, v ...

第一题貌似不能用Comparator, 主要是要把ch当成一个字母算,除非你自己实现Comparator 接口?

第二题我是写了 hash (key: long url, value: short url),面试官说要讲讲生成方法所以我说short url 可以用long url + MD5 生成,顺便在hashcode的方法里生成,但是我觉得好像不大对...
回复 支持 反对

使用道具 举报

杰西Jesse 发表于 2015-11-15 01:37:19 | 显示全部楼层
alikewmk 发表于 2015-11-14 14:24
第一题貌似不能用Comparator, 主要是要把ch当成一个字母算,除非你自己实现Comparator 接口?

第二题 ...
. visit 1point3acres.com for more.
感觉第二题如果用长的做key的话,那么long->short就是查询map,然后给短的怎么知道长的呢?
第一题写了一下code,觉得好麻烦的样子T T。。
  1. import java.util.*;
  2. . From 1point 3acres bbs
  3. class NewString implements Comparable<NewString> {
  4.         String str;
  5.         static String[] orderMap;

  6.         NewString(String string) {
  7.                 str = string;
  8.         }

  9.         public int[] getOrder(String s) {
  10.                 int[] result = new int[2];
  11.                 for (int i = 0; i < orderMap.length; i++) {
  12.                         if (orderMap[i].startsWith(s)) {
  13.                                 result[0] = i;
  14.                                 result[1] = orderMap[i].length();
  15.                                 return result;. 鍥磋鎴戜滑@1point 3 acres
  16.                         }
  17.                 }. more info on 1point3acres.com
  18.                 result[0] = -1;
  19.                 result[1] = 0;
  20.                 return result;
  21.         }
  22. . Waral 鍗氬鏈夋洿澶氭枃绔,
  23.         @Override
  24.         public int compareTo(NewString o) {.鐣欏璁哄潧-涓浜-涓夊垎鍦
  25.                 // TODO Auto-generated method stub
  26.                 int i = 0, j = 0;. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  27.                 while (i < str.length() && i < o.str.length()) {
  28.                         String sub1 = str.substring(i, i + 1);
  29.                         String sub2 = o.str.substring(j, j + 1);
  30.                         int[] order1 = getOrder(sub1);
  31.                         int[] order2 = getOrder(sub2);
  32.                         if (order1[0] == -1 || order2[0] == -1) {
  33.                                 return 1;
  34.                         }. Waral 鍗氬鏈夋洿澶氭枃绔,
  35.                         i += order1[1];
  36.                         j += order2[1];
  37.                         if (sub1.equals(sub2))
  38.                                 continue;
  39.                         else {. From 1point 3acres bbs
  40.                                 return order1[0] - order2[0];
  41.                         }
  42.                 }. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  43.                 if (i == str.length() && i == o.str.length()) {
  44.                         return 0;
  45.                 } else {
  46.                         return i < str.length() ? 1 : -1;
  47.                 }
  48.         }
  49. . 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  50.         public static void setOrder(String[] order) { 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  51.                 // TODO Auto-generated method stub
  52.                 orderMap = order;
  53.         }
  54. . 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  55. }

  56. public class NewOrder {
  57.         String[] order = { "a", "b", "ch", "d" };

  58.         public void sortWord(String[] words) {-google 1point3acres
  59.                 NewString.setOrder(order);
  60.                 List<String> list = new ArrayList<>();
  61.                 Queue<NewString> que = new PriorityQueue<NewString>();. 1point 3acres 璁哄潧
  62.                 for (int i = 0; i < words.length; i++) {
  63.                         NewString newString = new NewString(words[i]);
  64.                         que.add(newString);
  65.                 }
  66.                 while (!que.isEmpty()) {
  67.                         list.add(que.poll().str);.鐣欏璁哄潧-涓浜-涓夊垎鍦
  68.                 }
  69.                 System.out.println(list);
  70.         }. Waral 鍗氬鏈夋洿澶氭枃绔,

  71. -google 1point3acres
  72.         public static void main(String args[]) {. From 1point 3acres bbs
  73.                 NewOrder newOrder = new NewOrder();
  74.                 String[] words = { "abch", "chba", "bch", "ach", "bb" };
  75.                 newOrder.sortWord(words);.1point3acres缃
  76.         }
  77. }
复制代码
回复 支持 反对

使用道具 举报

 楼主| alikewmk 发表于 2015-11-15 03:50:01 | 显示全部楼层
杰西Jesse 发表于 2015-11-15 01:37
感觉第二题如果用长的做key的话,那么long->short就是查询map,然后给短的怎么知道长的呢?
第一题写了一 ...

好详细的解法,赞一个~

第二题仔细思考了下就是要有两步:
. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
第一步: 给出长连接,利用长连接生成短连接(MD5)
第二步: 以短连接为key,长连接为value存入哈希表
.1point3acres缃
这样就可以实现相互查找了。

参考了这篇文章,说的更详细:
-google 1point3acres
http://noalgo.info/612.html
回复 支持 反对

使用道具 举报

吃啥才算成熟 发表于 2015-11-15 04:11:04 | 显示全部楼层
alikewmk 发表于 2015-11-15 03:50. From 1point 3acres bbs
好详细的解法,赞一个~. From 1point 3acres bbs

.鏈枃鍘熷垱鑷1point3acres璁哄潧第二题仔细思考了下就是要有两步:

lz什么时候面的?  收到消息了吗?
回复 支持 反对

使用道具 举报

宝贝忆彼岸 发表于 2015-11-15 04:15:54 | 显示全部楼层
请问lz第二题short URL怎么实现的,我想的是用base62来实现,先把long url换成id,然后再变成string base62 。。。还有请问怎么通过短的转长的呢?是再来一个hashmap保存,还是通过算法转回去?
回复 支持 反对

使用道具 举报

杰西Jesse 发表于 2015-11-15 04:33:46 | 显示全部楼层
宝贝忆彼岸 发表于 2015-11-15 04:15
请问lz第二题short URL怎么实现的,我想的是用base62来实现,先把long url换成id,然后再变成string base62 ...

应该用62吧。。。
回复 支持 反对

使用道具 举报

宝贝忆彼岸 发表于 2015-11-15 04:41:39 | 显示全部楼层
. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
请问你的思路是什么?和我一样吗?
回复 支持 反对

使用道具 举报

 楼主| alikewmk 发表于 2015-11-15 06:18:36 | 显示全部楼层
吃啥才算成熟 发表于 2015-11-15 04:11. 鍥磋鎴戜滑@1point 3 acres
lz什么时候面的?  收到消息了吗?

星期五,没消息呢还。
回复 支持 反对

使用道具 举报

杰西Jesse 发表于 2015-11-15 10:20:39 | 显示全部楼层
宝贝忆彼岸 发表于 2015-11-15 04:41
请问你的思路是什么?和我一样吗?

就是其实只要产生一个多少长度的key就行了。。
  1. private String generateKey() {. 鍥磋鎴戜滑@1point 3 acres
  2.                 String key = "";
  3.                 boolean flag = true;
  4.                 while (flag) {
  5.                         key = "";
  6.                         for (int i = 0; i < keyLength; i++) {
  7.                                 key += myChars[myRand.nextInt(62)];-google 1point3acres
  8.                         }
  9.                         if (!keyMap.containsKey(key)) {
  10.                                 flag = false;
  11.                         }
  12.                 }
  13.                 return key;
  14.         }
复制代码
其中random 产生一个0-61的数,然后mapping一下,保存两个hash, 一个short_url -> long_url, 一个是long_url_> short_url..  

补充内容 (2015-11-15 10:21):
key就是short_Url
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

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

custom counter

GMT+8, 2017-5-26 19:23

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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