一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
码农求职神器Triplebyte:
不用海投,内推多家公司面试
Airbnb 数据科学职位
in analytics and inference
游戏初创公司
招聘工程师、Designer和游戏策划
游戏初创公司DreamCraft招聘工程师、UIUX Designer和游戏策划
电商初创公司Good Days
招聘SDE/UI/TPM实习生
把贵司招聘信息放这里
查看: 1732|回复: 2
收起左侧

Twitch 电面经

[复制链接] |试试Instant~ |关注本帖
rcholic 发表于 2016-10-27 09:00:32 | 显示全部楼层 |阅读模式

2016(10-12月) 码农类 硕士 全职@Twitch - 内推 - 技术电面 |Other在职跳槽

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

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

x
板上很少有人面这个Twitch,上个月通过mitbbs的论坛找人内推,今天电面,45分钟;
可以说是只有一个题目,就是在Tree上找word,之后又变化成Graph找word
. 鍥磋鎴戜滑@1point 3 acres
在coderpad上写的代码,感觉写起来还不错

上来就问我是否知道BFS,我说知道
让我在一个tree上找是否存在word并写test cases

在我写完第一遍代码之后,又让我clean up,就大概变成了下面的:
. 鍥磋鎴戜滑@1point 3 acres
public class FindWordBFS {

    private class TreeNode {
        String data;. visit 1point3acres.com for more.
        TreeNode left;
        TreeNode right;
        
        public TreeNode(String data) {
            this.data = data;
        }
    }
    -google 1point3acres
    public boolean find(TreeNode root, String word) {
        if (root == null || word == null || word.isEmpty()) return false;
. 鍥磋鎴戜滑@1point 3 acres
        Queue<TreeNode> q = new LinkedList<>();.鏈枃鍘熷垱鑷1point3acres璁哄潧
        q.offer(root);
        
        while (q.size() > 0) {
            TreeNode node = q.poll();
            if (node == null) continue;
            if (node.data.equals(word)) return true;
            q.offer(node.left);
            q.offer(node.right);
        } 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
        
        return false;
    }

}. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
test cases:find(null, null);find(root, null);find(root, "");find(root, "hello");  // 树上有hellofind(null, "hello"); // 树上有hellofind(root, "world"); // 树上不存在world
一开始以为是二叉树,所以开始加了条件是往左还是往右转,但是电话那边说是unbalanced tree,我追问他澄清说:树上的 string 没有顺序,所以去掉了判断往左还是往右的两行
改完之后还是不满意,又说tree上可能有cycle,也就是说 两个节点可能有共享的 children 或 孙子节点索性,他让我改成了graph的写法,
所以,不得不把TreeNode class 重写成这个:
private class TreeNode {-google 1point3acres
    String data;
    List<TreeNode> children;

    public TreeNode(String data) {
        this.data = data;
        this.children = new ArrayList<>();
    }. visit 1point3acres.com for more.
}
所以在while里面又潜逃了一个for-loop来加children nodes, 但是还是有共享children 或 孙子节点的问题,所以我又不得不加了一个HashSet来存已经遍历过的节点。
整个40分钟用以上两种方法,很简单的问题,但是因为没问清楚,显得有点磨叽,最后我心里感觉不适很好。。。。
希望能过,但是也做好跪的准备了。-google 1point3acres
发一下面经,为明天的狗家店面攒人品!谢谢各位!

评分

1

查看全部评分

susan_dly 发表于 2017-1-19 10:12:32 | 显示全部楼层
楼主后来去onsite了吗?
回复 支持 反对

使用道具 举报

水花舞林 发表于 2017-4-2 04:31:35 | 显示全部楼层
楼主去onsite了吗
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2018-1-18 16:10

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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