一亩三分地论坛

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

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

PocketGem 第一次电面面经,怎么是新题啊!!!!!

[复制链接] |试试Instant~ |关注本帖
269644943 发表于 2015-11-4 06:16:44 | 显示全部楼层 |阅读模式

2015(10-12月) 码农类 硕士 全职@PoketGem - 网上海投 - 技术电面 |Failfresh grad应届毕业生

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

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

x
刚刚电面完, 网上看了好多面经,还准备的信心满满的。 结果白人小哥一来就贴了个新题。题目 大意: convert char[] = "BBBBCCCDDD"  to
                             char[] = "4B3C3D";.鏈枃鍘熷垱鑷1point3acres璁哄潧
                NOTE:  should do it in place!
. Waral 鍗氬鏈夋洿澶氭枃绔,

我只想到用stringbuilder, in-place 的想不出来。 妥妥的跪了, move on了。. 鍥磋鎴戜滑@1point 3 acres

. more info on 1point3acres.com这是我第一次技术电面, 总结下: 1. 打字慢, 有紧张的原因吧。 2. 看到新题就蒙了, 还是要多练。  3. 交流有问题,而且电话声音忽强忽弱
hpplayer 发表于 2015-11-4 09:31:49 | 显示全部楼层
我写了个不知道对不对,如果是IN-PLACE电话得把后面的CELL都设置为空吧
  1.           public static void main(String[] args) {.鏈枃鍘熷垱鑷1point3acres璁哄潧
  2.                 char[] ary = {'B','B','B','B','c','c','c', 'D', 'D', 'D', 'E'};
  3.                 char[] ary2 = {'B','B','B','B','c','c','c', 'D', 'D', 'D'};
  4.             System.out.println(buildString(ary2));
  5.           }
  6.           
  7.           public static String buildString(char[] ary){
  8.             int lastIndex = 0;
  9.             int count = 1;
  10. .1point3acres缃
  11.             for(int i = 0; i < ary.length; i++){
  12.               count = 1;
  13.              
  14.               while(i + 1< ary.length && ary[i] == ary[i+1]  ){
  15.                 i++;. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  16.                 count++;
  17.               }
  18.               ary[lastIndex++] = (char) (count + '0');
  19.               ary[lastIndex++] = ary[i];
  20.               if(i + 1 == ary.length){
  21.                 for(int j = lastIndex; j < ary.length; j++){
  22.                   ary[j] = ' ';
  23.                 }
  24.               }
  25.             }.鐣欏璁哄潧-涓浜-涓夊垎鍦
  26.             
  27.             
  28.             
  29.             return new String(ary);
  30.           }
复制代码
回复 支持 反对

使用道具 举报

inkhay 发表于 2015-11-5 07:08:07 | 显示全部楼层
不要意思问一下,如果是“BCD”的话,怎么做到in place?难道要return 1B1C1D?那不就长度都不够了么
回复 支持 反对

使用道具 举报

 楼主| 269644943 发表于 2015-11-5 08:47:08 | 显示全部楼层
inkhay 发表于 2015-11-5 07:08
不要意思问一下,如果是“BCD”的话,怎么做到in place?难道要return 1B1C1D?那不就长度都不够了么

BCD的话就 “bcd”   ,不需要加1 的
回复 支持 反对

使用道具 举报

elrohir 发表于 2015-11-5 09:44:04 | 显示全部楼层
inkhay 发表于 2015-11-5 07:08
不要意思问一下,如果是“BCD”的话,怎么做到in place?难道要return 1B1C1D?那不就长度都不够了么
.鐣欏璁哄潧-涓浜-涓夊垎鍦
这道题在别家的面试里有看到过,要求是返回的string长度要小于等于原始string,所以"BCD"只能返回"BCD"
回复 支持 反对

使用道具 举报

niyanwen212 发表于 2015-11-6 01:11:28 | 显示全部楼层
hpplayer 发表于 2015-11-4 09:31
我写了个不知道对不对,如果是IN-PLACE电话得把后面的CELL都设置为空吧

同学,但是你生成新的数组的长度还是和原来的数组一样,这有关系嘛?
回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

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

custom counter

GMT+8, 2016-12-11 06:16

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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