浏览 3117 次
锁定老帖子 主题:58校招成都站笔试题目
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2012-11-08
最后修改:2012-11-08
最后一个题目想看看大家是怎么看的。 是关于六隔定理的,意思是: 你和任何一个陌生人之间所间隔的人不会超过六个,也就是说,最多通过六个人你就能够认识任何一个陌生人。这就是六度分割理论,也叫小世界理论。 全局数据:Person[] persons //所有人的集合,已指定好朋友关系 Personl类定义: public class Person{ private int id; //person唯一标示符 private Person[] friends;//认识的人 } 实现接口 int getDualate(Person a,Person b) 返回两人之间最短关系是多少?如果超过六个人,就返回-1,如果互为朋友,就返回0. 另外就是优化算法,当6换成N, persons中数据量大于千万条的时候,如何优化算法. 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2012-11-08
有点难度。。。。
|
|
返回顶楼 | |
发表时间:2012-11-13
不知道能不能用到Dijkstra迪杰斯特拉算法
|
|
返回顶楼 | |
发表时间:2012-11-16
跟图中的最短路径是一回事吧。
|
|
返回顶楼 | |
发表时间:2012-11-16
最后修改:2012-11-16
这个还真不知道怎么弄,递归?
有一个叫neo4j的东西,不知道是不是干这个的 两个人同时查询下一级的相识的人,每查一级对比一下j结果中有没有相同的人? |
|
返回顶楼 | |