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

狗狗电面2面面筋,跪,2018-02-05

全局:

2018(1-3月) 码农类General 本科 全职@google - 内推 - 技术电面  | | Fail | 在职跳槽

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

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

x
狗狗电面2面,时间2月5日

题目:
给出一个有向图的结构
START --> a --> b --> c --> END

如果
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies
做到第四问的时候时间差不多快到了
小哥说没问题,我知道你的思路了(事实证明有问题)

move on了,希望对其他同学有帮助


上一篇:Sabre OA面经:bq + coding
下一篇:Bloomberg on campus 面经
推荐
luogaoqi 2018-2-13 05:57:39 | 只看该作者
全局:
这些A一定是同一个node吗 还是可以是3个不同的node with same value a,是否允许走环, 是否允许duplicate value node,题目都没说吧
回复

使用道具 举报

推荐
exthrash 2018-2-26 04:46:41 | 只看该作者
全局:
class GraphNode:
        def __init__(self, val):
                self.val = val
                self.neighbors = []


def is_valid(s, graph_start):
       
        if graph_start is None:
                return False

        # Suppose the start and end nodes in the graph have the value S and E
        s = 'S' + s + 'E'

        q = collections.deque([graph_start])

        for i in range(len(s)):
                matched = False
                qsize = len(q)

                for k in range(qsize):
                       
                        front = q.popleft()
                        curr_matched = (front.val == s[i])
                        matched = matched or curr_matched
                       
                        if curr_matched:
                                for neighbor in front.neighbors:
                                        q.append(neighbor)
                if not matched:
                        return False

        return True
回复

使用道具 举报

推荐
linjin 2018-2-12 23:39:30 | 只看该作者
全局:
bool checkUtil(string str, int pos, GraphNode *cur) {
  if (pos == str.length())
    return cur->isEnd;


  char curCh = str[pos];

  for (auto s : cur->succs) {
        if (s->ch == curCh) {
            if (checkUtil(str, pos+1, s))
                return true;
        }
  }
  return false;

}

bool checkWord(string str) {
  if (str.empty())
    return false;

  return checkUtil(str, 0, root);
}

main() {

    root = new GraphNode();

    GraphNode *an = new GraphNode('a');
    root->succs.push_back(an);

    GraphNode *bn = new GraphNode('b');
    an->succs.push_back(bn);

    GraphNode *a2n = new GraphNode('a');
    bn->succs.push_back(a2n);
    bn->succs.push_back(an);

    a2n->isEnd = true;

    printf("%s\n", checkWord("ababa") ? "true" : "false");
    printf("%s\n", checkWord("aba") ? "true" : "false");
    printf("%s\n", checkWord("ab") ? "true" : "false");
}
回复

使用道具 举报

🔗
cx101220012 2018-2-12 16:50:29 | 只看该作者
全局:
里面有重复字符是什么意思呢?
回复

使用道具 举报

🔗
devilnut 2018-2-12 23:40:24 | 只看该作者
全局:
这就是个Trie吧…
回复

使用道具 举报

🔗
hyliu0000 2018-2-13 00:43:57 | 只看该作者
全局:
用trie不行吗? 为什么要用图呢?

评分

参与人数 1大米 +5 收起 理由
krizalio001 + 5 给你点个赞!

查看全部评分

回复

使用道具 举报

🔗
harveyaya 2018-2-13 01:12:52 | 只看该作者
全局:
devilnut 发表于 2018-2-12 23:40
这就是个Trie吧…

Trie 怎么解决环呢?
回复

使用道具 举报

🔗
weile77 2018-2-13 03:19:24 | 只看该作者
全局:
这应该是个 BFS 题。DFS 不能解决环,即使是用 visited set 判断。比如一个字符串在环上绕过两圈之后可以找到 End。可以用一个 Queue 记录所有当前合法的节点,同时维护一个每层的节点数的 var。如果新的 char 和 queue.poll() 一样,就把它的 nexts 们 offer 进 queue中。结束条件是 END 的时候找到 END。重复字符问题也可以解决。
回复

使用道具 举报

🔗
 楼主| anastasia22 2018-2-13 04:28:08 | 只看该作者
全局:
weile77 发表于 2018-2-13 03:19
这应该是个 BFS 题。DFS 不能解决环,即使是用 visited set 判断。比如一个字符串在环上绕过两圈之后可以找 ...

是的,明显的BFS题目,主要是follow up
回复

使用道具 举报

🔗
 楼主| anastasia22 2018-2-13 04:28:34 | 只看该作者
全局:
harveyaya 发表于 2018-2-13 01:12
Trie 怎么解决环呢?

Trie不行的,因为follow up有提到,有可能有环
回复

使用道具 举报

🔗
 楼主| anastasia22 2018-2-13 04:32:04 | 只看该作者
全局:
ryuichist 发表于 2018-2-13 04:28
是的,明显的BFS题目,主要是follow up

比如这种情况

START -> a <--> a <--> a -> END
回复

使用道具 举报

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

本版积分规则

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