一亩三分地论坛

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

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

Google 电面

[复制链接] |试试Instant~ |关注本帖
yanyan2060 发表于 2016-5-17 08:39:33 | 显示全部楼层 |阅读模式

2016(4-6月) 码农类 硕士 全职@Google - 内推 - 技术电面 |Passfresh grad应届毕业生

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

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

x
先问了一个project就做题了~~
就一道题:decompression string
. Waral 鍗氬鏈夋洿澶氭枃绔,
input : abbaba4x[a]bb3x[abaa2x[bab]]
output : abbabaaaaabbabaababbababaababbababaababbab


之前好像看过类似的面经,谢谢地里的同胞。就用了stack就可以了把不是‘]’的push,遇见']'就开始pop, 并且保存直到'['然后再看要重复几次再扔进栈里这么多次, 说了思路那边都没有回应。。吓人。写完本来他还要问什么我听不太清就说算了然后问他问题。。。口述跑了下case。还写出了一个小bug..提示后改了。
求onsite好运!!攒人品!!!

评分

1

查看全部评分

本帖被以下淘专辑推荐:

DaveLiu 发表于 2016-5-22 10:17:43 | 显示全部楼层
思路没错,撸出来了,欢迎改进意见. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴

  1. public String decompressString(String s) {
  2.         Stack<String> stack = new Stack<String>();
  3.         StringBuilder result = new StringBuilder();
  4.         StringBuilder nested = new StringBuilder(); .鐣欏璁哄潧-涓浜-涓夊垎鍦
  5.         for (int i = 0; i < s.length(); i++) {.鐣欏璁哄潧-涓浜-涓夊垎鍦
  6.                 char c = s.charAt(i);
  7.                 if (c >= '0' && c <= '9') {
  8.                         String pattern = s.substring(i, i + 2);
  9.                         i += 3;
  10.                         while (s.charAt(i) >= 'a' && s.charAt(i) <= 'z') {
  11.                                 pattern += s.charAt(i);. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  12.                                 i++;
  13.                         }
  14.                         i--;
  15.                         stack.push(pattern);
  16.                 } else if (c == ']') {.鏈枃鍘熷垱鑷1point3acres璁哄潧
  17.                         String[] pop = stack.pop().split("x");
  18.                         String pattern = "";
  19.                         for (int j = 0; j < Integer.parseInt(pop[0]); j++) {.鐣欏璁哄潧-涓浜-涓夊垎鍦
  20.                                 pattern += pop[1] + nested.toString();
  21.                         }
  22.                         nested.setLength(0);
  23.                         nested.append(pattern);
  24.                         if (stack.empty()) {
  25.                                 result.append(nested.toString());
  26.                                 nested.setLength(0); 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  27.                         }
  28.                 } else {
  29.                         result.append(c);
  30.                 }
  31.         }
  32.         return result.toString();
  33. }
复制代码

补充内容 (2016-5-22 10:19):
assume string里面只有小写字母,只用了楼主一个test case来validate
回复 支持 反对

使用道具 举报

yueliu2366 发表于 2016-5-22 10:42:04 | 显示全部楼层
恭喜楼主,希望你顺利拿下onsite。 这已经是这个月内我看到的第3次考到压缩的题目了,简直超过了longest consecutive path成为第一高频了。
回复 支持 反对

使用道具 举报

jy_121 发表于 2016-5-22 10:50:29 | 显示全部楼层
DaveLiu 发表于 2016-5-22 10:17
思路没错,撸出来了,欢迎改进意见

要是次数不止一位数你这样截取就不行了吧?
回复 支持 反对

使用道具 举报

DaveLiu 发表于 2016-5-22 11:49:11 | 显示全部楼层
jy_121 发表于 2016-5-22 10:50
要是次数不止一位数你这样截取就不行了吧?

是的,当时也考虑到了,但是除了用regex,不知道有更好的方法不?
回复 支持 反对

使用道具 举报

jy_121 发表于 2016-5-22 13:18:08 | 显示全部楼层
DaveLiu 发表于 2016-5-22 11:49
是的,当时也考虑到了,但是除了用regex,不知道有更好的方法不?

就是截取的时候一直截到x呢,比如用index of 找到离当前最近的x的下标
回复 支持 反对

使用道具 举报

sal12 发表于 2016-6-8 07:53:15 | 显示全部楼层
  1.         . 1point 3acres 璁哄潧
  2. public String decompressString(String s) {
  3.                 StringBuilder res = new StringBuilder();
  4.                 StringBuilder current = new StringBuilder();.鐣欏璁哄潧-涓浜-涓夊垎鍦
  5.                 int i = 0;. 1point 3acres 璁哄潧
  6.                 Stack<Integer> vals = new Stack<>();
  7.                 Stack<StringBuilder> strs = new Stack<>();
  8.                 while(i < s.length()){
  9.                         char c = s.charAt(i);-google 1point3acres
  10.                         if(c >= 'a' && c <= 'z'){
  11.                                 current.append(c);
  12.                         } else if (c >= '0' && c <= '9'){
  13.                                 int val = 0;
  14.                                 while(i < s.length() && s.charAt(i) >= '0' && s.charAt(i) <= '9'){
  15.                                         val = val * 10 + s.charAt(i) - '0';
  16.                                         i++;
  17.                                 }
  18.                                 i++;
    .鐣欏璁哄潧-涓浜-涓夊垎鍦
  19.                                 vals.push(val);.鏈枃鍘熷垱鑷1point3acres璁哄潧
  20.                                 continue;
  21.                         } else if (c == '['){
  22.                                 strs.push(current);
  23.                                 current =  new StringBuilder();
  24.                         } else if (c == ']'){
  25.                                 int repeat = vals.pop();
  26.                                 String str = current.toString();
  27.                                 for(int j = 0; j < repeat - 1; j++){
  28.                                         current.append(str);
  29.                                 }
  30.                                 if(strs.isEmpty() == false){
  31.                                         strs.peek().append(current);
  32.                                 } else {
  33.                                         strs.push(current);
  34.                                 }
  35.                         }
  36.                         i++;
  37.                 }. from: 1point3acres.com/bbs
  38.                 return res.toString();
  39.         }
复制代码
. from: 1point3acres.com/bbs

我也写了下
回复 支持 反对

使用道具 举报

davidwolfe 发表于 2016-6-8 08:19:11 | 显示全部楼层
恭喜lz! 要是截取的string里面本来就有xxx这种情况就不好这么做了吧
回复 支持 反对

使用道具 举报

anbmic 发表于 2016-6-8 11:49:55 | 显示全部楼层
sal12 发表于 2016-6-8 07:53 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
我也写了下

我觉得把vals和strs合并成一个新object的话其实会更清晰:)
回复 支持 反对

使用道具 举报

hyj143 发表于 2016-6-10 02:47:00 | 显示全部楼层
有人是用递归做的么
回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

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

custom counter

GMT+8, 2016-12-11 19:56

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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