一亩三分地论坛

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

一亩三分地官方iOS手机应用下载
查看: 553|回复: 1
收起左侧

Twitch 电面经

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

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

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

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

x
板上很少有人面这个Twitch,上个月通过mitbbs的论坛找人内推,今天电面,45分钟;.鐣欏璁哄潧-涓浜-涓夊垎鍦
可以说是只有一个题目,就是在Tree上找word,之后又变化成Graph找word

在coderpad上写的代码,感觉写起来还不错. Waral 鍗氬鏈夋洿澶氭枃绔,

上来就问我是否知道BFS,我说知道
让我在一个tree上找是否存在word并写test cases
鏉ユ簮涓浜.涓夊垎鍦拌鍧.
在我写完第一遍代码之后,又让我clean up,就大概变成了下面的:

public class FindWordBFS {

    private class TreeNode {. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
        String data;
        TreeNode left;. 1point3acres.com/bbs
        TreeNode right;. 1point3acres.com/bbs
        
        public TreeNode(String data) {
            this.data = data;
        }
    }
    . visit 1point3acres.com for more.
    public boolean find(TreeNode root, String word) {
        if (root == null || word == null || word.isEmpty()) return false;. 鍥磋鎴戜滑@1point 3 acres

        Queue<TreeNode> q = new LinkedList<>();
        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);. visit 1point3acres.com for more.
            q.offer(node.right);
        }
        
        return false;
    }. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
. from: 1point3acres.com/bbs
}. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
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 {. 1point 3acres 璁哄潧
    String data; 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
    List<TreeNode> children;

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

评分

1

查看全部评分

susan_dly 发表于 2017-1-19 10:12:32 | 显示全部楼层
关注一亩三分地公众号:
Warald_一亩三分地
楼主后来去onsite了吗?
回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

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

custom counter

GMT+8, 2017-3-29 00:07

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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