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

Google 店面 一轮 过了

全局:

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

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

x
店面一轮,题目是给一个double linked list,给一个subset of nodes in this
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies
p)

解法在回答里面,求加米,没权限看不了面经很难过



评分

参与人数 14大米 +68 收起 理由
letranger + 1 给你点个赞!
tenpoint + 5 很有用的信息!
forgarden + 3 很有用的信息!
bambu + 3 给你点个赞!
sonofspring + 3 很有用的信息!

查看全部评分


上一篇:Nutanix 电面2
下一篇:灵隐电面
推荐
BigShaun 2018-3-15 05:16:03 | 只看该作者
全局:
就是hash table的题吧。遍历一个节点的时候把他前后节点的计数+1,遍历之后的节点时如果有对应的key已经在表中,我们减去对应的value。

public int numberOfGroup(Set<DLinkedNode> set){
        Map<DLinkedNode, Integer> map = new HashMap<>();
       
        int count = 0;
        for(DLinkedNode node : set){
            count++;
            
            int sameGroup= map.getOrDefault(node, 0);
            count -= sameGroup;
            
            if(node.pre!=null)
                map.put(node.pre, map.getOrDefault(node.pre, 0)+1);
            if(node.post!=null)
                map.put(node.post, map.getOrDefault(node.post, 0)+1);
        }
       
        return count;
    }
回复

使用道具 举报

推荐
zyy_123 2018-3-14 15:11:05 | 只看该作者
全局:
为何要额外set 直接随便选一个然后在linkedlist里左右延伸 边延伸边删除set里元素 直到两头都不在set里 然后重复操作直到set为空
回复

使用道具 举报

推荐
yzkst06100 2018-3-14 23:56:49 | 只看该作者
全局:
没给head 那就这样,不知道这个list里面有没有环

public int groupList(Set<Node> set) {
                Set<Node> visited = new HashSet<>();
                int res = 0;
                for (Node i : set) {
                        if (visited.contains(i)) continue;
                        res ++;
                        visited.add(i);
                        left(i,visited,set);
                        right(i,visited,set);
                }
                return res;
        }
        private void left(Node temp, Set<Node> visited , Set<Node> set) {
                if (temp == null || temp.left == null) return;
                if (!set.contains(temp.left) || visited.contains(temp.left)) {
                        return;
                       
                }else {
                        visited.add(temp.left);
                        left(temp.left , visited , set);
                }
                return;
        }
回复

使用道具 举报

🔗
 楼主| CharlesLeeSysu 2018-3-14 13:04:22 | 只看该作者
全局:
解法一
union-find, google很喜欢union find和分组的题啊,要求良好基本功才能在20分钟写出来,然而我没有

解法二:
思路来源于2 sum,merge interval, k-empty slot(oa 题)
用两个set保存所有group的左右边界(exclusive)节点
比如 group{2}, left存1,right存3。
等到遍历到3,存在于right中,删除掉3,把3.next(4)放入right,count 不变
同理对于left。
当一个节点同时,在left和right中,说明可以concatenate两个group,group count--,update left and right
不在left,right就新开一个group,add its prev and next separately to left and right.
O(n) time and space

评分

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

查看全部评分

回复

使用道具 举报

🔗
yzkst06100 2018-3-14 23:22:17 | 只看该作者
全局:
zyy_123 发表于 2018-3-14 15:11
为何要额外set 直接随便选一个然后在linkedlist里左右延伸 边延伸边删除set里元素 直到两头都不在set里 然 ...

我想了一种方法,但是没解决set里面iteration的问题,会报错,但原理应该是对的;不知道有没有办法解决

public int groupList(ListNode head , Set<Node> set) {
        int origin = count(head);//count the num of nodes
        int res = 0;
        for (Node cur : set) {
                res ++;
                if (set.contains(cur.left)) {
                        left(cur , set);
                }
                if (set.contains(cur.right)) {
                        right(cur , set);
                }
                set.remove(cur);
        }
        return origin - res;
}
private void left(Node temp, Set<Node> s) {
        if (temp == null) return;
        if (s.contains(temp.left)) {
                left(temp.left,s);
                s.remove(temp.left);
        }
        return;
}
回复

使用道具 举报

🔗
 楼主| CharlesLeeSysu 2018-3-14 23:23:20 | 只看该作者
全局:
你的做法对于offline可以,但我写的能online,这是我想的唯一优势。
回复

使用道具 举报

🔗
 楼主| CharlesLeeSysu 2018-3-14 23:24:04 | 只看该作者
全局:
zyy_123 发表于 2018-3-14 15:11
为何要额外set 直接随便选一个然后在linkedlist里左右延伸 边延伸边删除set里元素 直到两头都不在set里 然 ...

Online优势
回复

使用道具 举报

🔗
 楼主| CharlesLeeSysu 2018-3-14 23:28:46 | 只看该作者
全局:
yzkst06100 发表于 2018-3-14 23:22
我想了一种方法,但是没解决set里面iteration的问题,会报错,但原理应该是对的;不知道有没有办法解决
...

没给head 忘了说
再有要同时考虑left right都包含cur,否则left right更新错误
回复

使用道具 举报

🔗
eejchen 2018-3-15 00:11:23 | 只看该作者
全局:
这个题目没太看懂。。。就lz举的这个例子来说,构成哪几个group呢?求解答一下
回复

使用道具 举报

🔗
 楼主| CharlesLeeSysu 2018-3-15 00:13:07 | 只看该作者
全局:
double linked list: 1,2,3,4,5
subset : {1,2,5}
{1,2,5}能构成2个group(相连为一个group); 1,2 一个,5一个

评分

参与人数 1大米 +3 收起 理由
forgarden + 3 很有用的信息!

查看全部评分

回复

使用道具 举报

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

本版积分规则

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