📣 独立日限时特惠: VIP通行证立减$68
回复: 18
跳转到指定楼层
上一主题 下一主题
收起左侧

Google电面

全局:

2016(10-12月) 码农类General 硕士 全职@google - 内推 - 技术电面  | | Other | 应届毕业生
好像是个美国小哥,叫Micheal, 上来直接贴题:
第一题: 给出一个dictionary,给出一个list里面包含首字母, output:在dictionary中
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies
sad...


补充内容 (2016-10-7 02:41):
第二题output:2

本帖子中包含更多资源

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

x

评分

参与人数 3大米 +36 收起 理由
hongye88 + 1 很有用的信息!
洋葱a + 5 感谢分享!
夏虫不知雪花 + 30

查看全部评分


上一篇:LinkedIn 电面面经
下一篇:前几天的facebook电面

本帖被以下淘专辑推荐:

  • · Google|主题: 458, 订阅: 133
推荐
木易wen 2016-10-19 03:27:35 | 只看该作者
全局:
第二题已光荣登上lc大榜 https://leetcode.com/problems/sentence-screen-fitting/
回复

使用道具 举报

全局:
第二题感觉就直接scan array吧,用几个pointer记录位置,注意考虑corner case就行,简单写了下,能run 图里的test case.

public static int solution(String[] text, int c, int l) {

                int count = 0, index = 0, indexCol = 0, res = 0;
                while (count < l) {
                        String word = text[index];
                        // one line cannot hold the whole word.
                        if (word.length() > c)
                                return 0;

                        // add to next line
                        if (c - indexCol < word.length()) {
                                count++;
                                indexCol = word.length() - 1;
                        }

                        // add to current line
                        else {
                                indexCol += word.length() - 1;
                                if (indexCol + 1 == c - 1) {
                                        indexCol = 0;
                                        count++;
                                }
                                if (indexCol + 1 == c) {
                                        indexCol = c > 1 ? 1 : 0;
                                        count = c > 1 ? count + 1 : count + 2;
                                }
                        }

                        // move to next word or return to first word
                        if (++index == text.length) {
                                index = 0;
                                if (count < l) res++;
                        }
                }
                return res;
        }
回复

使用道具 举报

推荐
b20160819 2016-10-28 02:48:47 | 只看该作者
全局:
兰台 发表于 2016-10-8 03:56
我也提供了这种思路 然后小哥说这和hashmap有啥区别 我说没区别都是O(N)。。所以就还是写的hashmap。。

谢谢楼主分享!输入的list里只是char, 感觉hash map更简单;如果是不定长度的的string作为prefix,还是trie好点
回复

使用道具 举报

🔗
lxxxxxxx 2016-10-7 02:46:00 | 只看该作者
全局:
都好难啊.... 请问一下楼主咋做的?
回复

使用道具 举报

🔗
XavierWangXY 2016-10-7 02:58:29 | 只看该作者
全局:
第一题 类似inverted index 存一个 首字母->单词列表的 hashmap。单词列表可以用以单词长度为weight的heap
回复

使用道具 举报

🔗
xihaokai1 2016-10-7 03:19:08 | 只看该作者
全局:
第二题greedy?
回复

使用道具 举报

🔗
白丁117 2016-10-7 03:42:53 | 只看该作者
全局:
没看懂题啥意思...lz可以解释下吗?多谢~
回复

使用道具 举报

🔗
mdzzxswl 2016-10-7 03:48:18 | 只看该作者
全局:
为什么电面 会有 截图。。。
回复

使用道具 举报

🔗
virpro 2016-10-7 06:40:13 | 只看该作者
全局:
第一题定义一个Map<Character, List<String>>,key是首字母,List<String>存最长的String。然后遍历dictionary同时update这个map。这样做可以吗?
回复

使用道具 举报

🔗
 楼主| 兰台 2016-10-8 00:43:18 | 只看该作者
全局:
第一题我就是一个先扫一遍list用HashSet<Character>存要找的首字母。再扫一遍dict用一个HashMap<Character, String>存最长的string。第二题就说了下思路,面试官也没给啥提示。。
回复

使用道具 举报

🔗
virpro 2016-10-8 01:50:38 | 只看该作者
全局:
兰台 发表于 2016-10-8 00:43
第一题我就是一个先扫一遍list用HashSet存要找的首字母。再扫一遍dict用一个HashMap存最长的string。第二 ...

如果同一个character有两个最长的String你怎么解决?比如hello, heard。
回复

使用道具 举报

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

本版积分规则

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