回复: 13
跳转到指定楼层
上一主题 下一主题
收起左侧

11/23 Google Intern Interview

全局:

2016(7-9月) 码农类General 本科 实习@google - 内推 - 技术电面  | | Other | 其他

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

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
感觉题都不是很难,很可能机会没把握住哎
第一个纽约打来的国人小哥,两道题。第一题给一个字符串,把里面的元音字母reverse
第二题给一个sorted array和一个数字,在
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies
等来offer是不是基本没戏了。
话说一般发offer是邮件,悲剧了是打电话这样子吗?

上一篇:Guidewire电面
下一篇:问一道 Airbnb csv parser的题
全局:
根据楼主的意思,重新改了下代码,谢谢
  1. public class MergeIntervalsIII {
  2.         public static void main(String[] args) {
  3.                 List<Interval> intervals = new ArrayList<Interval>();
  4.                 intervals.add(new Interval(4, 8));
  5.                 intervals.add(new Interval(3, 4));
  6.                 intervals.add(new Interval(-1, 2));
  7.                 intervals.add(new Interval(10, 12));

  8.                 List<Interval> res = mergeIntervals(intervals);
  9.                 for (Interval interval : res) {
  10.                         System.out.println(interval.start + " " + interval.end);
  11.                 }
  12.         }
  13.        
  14.         static class Interval {
  15.                 int start;
  16.                 int end;

  17.                 Interval() {
  18.                         start = 0;
  19.                         end = 0;
  20.                 }
  21.                 Interval(int s, int e) {
  22.                         start = s;
  23.                         end = e;
  24.                 }
  25.         }
  26.        
  27.         /*
  28.                  intervals.add(new Interval(4, 8));
  29.                 intervals.add(new Interval(3, 5));
  30.                 intervals.add(new Interval(-1, 5));
  31.                 intervals.add(new Interval(10, 12));
  32.                 这个case 应该是返回(10, 12)
  33.          */
  34.         public static List<Interval> mergeIntervals(List<Interval> intervals) {
  35.                 List<Interval> res = new ArrayList<Interval>();
  36.                 if (intervals == null || intervals.size() == 0) {
  37.                         return res;
  38.                 }
  39.                 Collections.sort(intervals, new Comparator<Interval>(){
  40.                         public int compare(Interval i1, Interval i2) {
  41.                                 if (i1.start == i2.start) {
  42.                                         return i1.end - i2.end;
  43.                                 }
  44.                                
  45.                                 return i1.start - i2.start;
  46.                         }
  47.                 });
  48.                 List<Interval> list = new ArrayList<Interval>();
  49.                 boolean[] isOverlap = new boolean[intervals.size()];
  50.                 list.add(intervals.get(0));
  51.                 for (int i = 1; i < intervals.size(); i++) {
  52.                         if (intervals.get(i).start < list.get(list.size() - 1).end) {
  53.                                 isOverlap[i] = true;
  54.                                 isOverlap[i - 1] = true;
  55.                                 list.get(list.size() - 1).end = Math.max(list.get(list.size() - 1).end, intervals.get(i).end);
  56.                         } else {
  57.                                 list.add(intervals.get(i));
  58.                         }
  59.                 }
  60.                 for (int i = 0; i < intervals.size(); i++) {
  61.                         if (!isOverlap[i]) {
  62.                                 res.add(intervals.get(i));
  63.                         }
  64.                 }
  65.                 return res;
  66.         }
  67. }
复制代码
回复

使用道具 举报

全局:
interval,这个问题如果两个interval[2, 4], [4, 6],要remove两个吗?
写了下代码,有相等也remove.
  1. public class MergeIntervalsIII {
  2.         public static void main(String[] args) {
  3.                 List<Interval> intervals = new ArrayList<Interval>();
  4.                 intervals.add(new Interval(4, 8));
  5.                 intervals.add(new Interval(3, 5));
  6.                 intervals.add(new Interval(-1, 2));
  7.                 intervals.add(new Interval(10, 12));

  8.                 List<Interval> res = mergeIntervals(intervals);
  9.                 for (Interval interval : res) {
  10.                         System.out.println(interval.start + " " + interval.end);
  11.                 }
  12.         }
  13.        
  14.         static class Interval {
  15.                 int start;
  16.                 int end;

  17.                 Interval() {
  18.                         start = 0;
  19.                         end = 0;
  20.                 }

  21.                 Interval(int s, int e) {
  22.                         start = s;
  23.                         end = e;
  24.                 }
  25.         }
  26.        
  27.        
  28.         public static List<Interval> mergeIntervals(List<Interval> intervals) {
  29.                 List<Interval> res = new ArrayList<Interval>();
  30.                 if (intervals == null || intervals.size() == 0) {
  31.                         return res;
  32.                 }
  33.                 Collections.sort(intervals, new Comparator<Interval>(){
  34.                         public int compare(Interval i1, Interval i2) {
  35.                                 if (i1.start == i2.start) {
  36.                                         return i1.end - i2.end;
  37.                                 }
  38.                                
  39.                                 return i1.start - i2.start;
  40.                         }
  41.                 });
  42.                 for (int i = 0; i < intervals.size(); i++) {
  43.                         if (res.size() == 0 || intervals.get(i).start > res.get(res.size() - 1).end) {
  44.                                 res.add(intervals.get(i));
  45.                         } else {
  46.                                 while (res.size() > 0 && intervals.get(i).start <= res.get(res.size() - 1).end) {
  47.                                         res.remove(res.size() - 1);
  48.                                 }
  49.                         }
  50.                 }
  51.                
  52.                 return res;
  53.         }
  54. }
复制代码

补充内容 (2015-12-3 04:56):
这个代码有错
回复

使用道具 举报

推荐
 楼主| tanpf5 2015-11-25 05:48:01 | 只看该作者
全局:
jacyjia 发表于 2015-11-25 05:24
我也是昨天面的今天没消息 一直在安慰自己过节了可能慢一点 TAT

今天查了下,速度基本取决于面试官上报的时间,规定在两周之内上报。
所以他们如果手头有活儿拖两天也是正常的,等等看吧
回复

使用道具 举报

🔗
corn 2015-11-24 23:41:09 | 只看该作者
全局:
三小时,这得有多快的feedback才可以啊。。。正常情况下等两个星期都是有可能的吧。。。
楼主加油~
回复

使用道具 举报

🔗
curry97 2015-11-25 00:30:41 | 只看该作者
全局:
merge interval那题怎么做啊?
回复

使用道具 举报

🔗
 楼主| tanpf5 2015-11-25 00:34:36 | 只看该作者
全局:
curry97 发表于 2015-11-25 00:30
merge interval那题怎么做啊?

可以先在leetcode上把merge interval搞懂,然后这里面只要纪录一下被merge的intervals最后remove掉就可以了
回复

使用道具 举报

🔗
 楼主| tanpf5 2015-11-25 00:35:34 | 只看该作者
全局:
corn 发表于 2015-11-24 23:41
三小时,这得有多快的feedback才可以啊。。。正常情况下等两个星期都是有可能的吧。。。
楼主加油~

我看好像地里已经有人昨天面试拿到offer了。。而且我周围过的人一般出结果很快,现在很慌啊
回复

使用道具 举报

🔗
jacyjia 2015-11-25 05:24:01 | 只看该作者
全局:
tanpf5 发表于 2015-11-25 00:35
我看好像地里已经有人昨天面试拿到offer了。。而且我周围过的人一般出结果很快,现在很慌啊

我也是昨天面的今天没消息 一直在安慰自己过节了可能慢一点 TAT
回复

使用道具 举报

🔗
jacyjia 2015-11-25 10:36:03 | 只看该作者
全局:
tanpf5 发表于 2015-11-25 05:48
今天查了下,速度基本取决于面试官上报的时间,规定在两周之内上报。
所以他们如果手头有活儿拖两天也是 ...

每天都很忐忑啊! 谢谢楼主~希望都可以pass~
回复

使用道具 举报

🔗
 楼主| tanpf5 2015-12-3 00:36:46 | 只看该作者
全局:
bobzhang2004 发表于 2015-12-3 00:31
interval,这个问题如果两个interval[2, 4], [4, 6],要remove两个吗?
写了下代码,有相等也remove.

我记得当时我问过这个问题,相等不算重叠,不删除
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

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