解算法题,送offer

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/z50L2O08e2u4afToR9A/article/details/83965338

两件事情。


第一件,近期算法类文章挺受欢迎的。

因此,决定后续多写这个专题

画外音:很多校招生留言,说这个专题对拿校招offer很有帮助。


第二件,快狗打车2019校园招聘启动。

画外音:听说,这个公司的技术负责人,是“架构师之路”的小编。


前端,后端,测试,移动等多个岗位。


今天,找出一道自己13年出的校招笔试题,对校招岗位感兴趣的朋友,评论给我解题思路,我直接发offer


题目:求微信群的覆盖


微信有很多群,现进行如下抽象:

(1) 每个微信群由一个唯一的gid标识;

(2) 微信群内每个用户由一个唯一的uid标识;

(3) 一个用户可以加入多个群;

(4) 群可以抽象成一个由不重复uid组成的集合,例如:

g1{u1, u2, u3}

g2{u1, u4, u5}

可以看到,用户u1加入了g1与g2两个群。

画外音,注意:

gid和uid都是uint64;

集合内没有重复元素;


假设微信有M个群(M为亿级别),每个群内平均有N个用户(N为十级别).


现在要进行如下操作:

(1)  如果两个微信群中有相同的用户则将两个微信群合并,并生成一个新微信群;

例如,上面的g1和g2就会合并成新的群:

g3{u1, u2, u3, u4, u5};

画外音:集合g1中包含u1,集合g2中包含u1,合并后的微信群g3也只包含一个u1。

(2) 不断的进行上述操作,直到剩下所有的微信群都不含相同的用户为止

将上述操作称:求群的覆盖。


设计算法,求群的覆盖,并说明算法时间与空间复杂度。


有兴趣一起共事的校招生,评论解题思路,直接拿offer当然,这篇文章不是挖坑,后续撰文解析答案。


算法,其实还是挺有意思的。

画外音:如果有学弟学妹在找工作,可以把文章转给ta们。

640?wx_fmt=jpeg

架构师之路-分享可落地的技术文章


TopK,数1,斐波拉契数列

拜托,面试别再问我TopK了!

拜托,面试别再问我数1了!

拜托,面试别再问我斐波那契数列了!


算法时间复杂度

拜托,面试别再问我时间复杂度了!


复杂度为O(n)的排序算法

拜托,面试别再问我基数排序了!

拜托,面试别再问我计数排序了!

拜托,面试别再问我桶排序了!


奇特排序算法

世界上最漂亮的排序算法!

猜你喜欢

转载自blog.csdn.net/z50L2O08e2u4afToR9A/article/details/83965338
今日推荐