免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 25242 | 回复: 85
打印 上一主题 下一主题

[算法] 淘宝2012校招题目,高手们请进 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-09-21 21:01 |只看该作者 |倒序浏览
一颗树上有海量结点,假设在亿这个级别,现在给定任意2个结点(非根结点),请找出他们共同的祖先结点,请在节省空间的前提下,高效查找。
注意:请勿对该树对做任何假设,它不一定是平衡树,也不一定有序。请高手们指教。

论坛徽章:
0
2 [报告]
发表于 2011-09-22 05:37 |只看该作者
1,如果树的节点不包含深度信息,那么通过递归回到根节点求出深度信息
2,建立2个游标,分别指向2个节点
3,比较节点的深度,移动较深得那个节点得游标指向其父节点
4,比较2个游标,如果指向同一节点,则该节点为共同祖先,否则回到第3步

如果深度信息为已知,算法复杂度为O(n),n是2个节点之间得距离
如果深度信息为未知,算法复杂度为O(N),n是2个节点得深度和

论坛徽章:
0
3 [报告]
发表于 2011-09-22 07:22 |只看该作者
这只能通过类似遍历的方式。
从一个节点出发,回溯到其父节点,然后遍历该父节点的所有字节点,如果找到了另一个节点,则该父节点就是它们共同的父节点,如果找不到,则回溯该父节点的父节点,继续如上查找。

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
4 [报告]
发表于 2011-09-22 08:18 |只看该作者
A小狗 一直爬,一直尿,直到爬到根节点
B小狗 一直爬,一直嗅,直到嗅到尿骚味
当然,还可以更快点,就是A和B都撒尿,都嗅,一起爬

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
5 [报告]
发表于 2011-09-22 10:18 |只看该作者
A小狗 一直爬,一直尿,直到爬到根节点
B小狗 一直爬,一直嗅,直到嗅到尿骚味
当然,还可以更快点,就是 ...
bruceteen 发表于 2011-09-22 08:18


好办法, 但如何节省空间呢?

论坛徽章:
2
技术图书徽章
日期:2013-09-04 15:21:51酉鸡
日期:2013-11-01 21:20:20
6 [报告]
发表于 2011-09-22 10:26 |只看该作者
好办法, 但如何节省空间呢?
zylthinking 发表于 2011-09-22 10:18


这个不需要额外的空间吧?
将节点按照固定尺寸内存对齐,每个指针的后几位就可以保存访问状态了。轨迹有了,相互比较一下就行了。

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
7 [报告]
发表于 2011-09-22 10:34 |只看该作者
这个不需要额外的空间吧?
将节点按照固定尺寸内存对齐,每个指针的后几位就可以保存访问状态了。轨迹 ...
mirnshi 发表于 2011-09-22 10:26


这样就是对节点自身地址做假设了; 而且, 即便如此, 仍需要第2遍遍历将状态恢复原始状态

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
8 [报告]
发表于 2011-09-22 11:07 |只看该作者
本帖最后由 zylthinking 于 2011-09-22 11:09 编辑

倒是想了个办法, 就是有点猥琐, 向上遍历时, 将兄弟节点的地址+1, 这样, 兄弟节点也到达时, 会发现自己的地址既不是 left_child, 也不是right_child, 则找到共同父节点; 然后各自从自身开始重新遍历直到共同父节点, 这一次是修正之前的修改, 将兄弟节点地址 -1; 在然后从共同父节点一直向上, 直到第一次遍历时到达的最高节点, 同样是修正之前的修改。

优点是空间O(1); 缺点是2次遍历, 每个节点都会做写操作,不够高效, 而且是独占式操作, 在未恢复修改前, 树结构其实被破坏了。

论坛徽章:
2
技术图书徽章
日期:2013-09-04 15:21:51酉鸡
日期:2013-11-01 21:20:20
9 [报告]
发表于 2011-09-22 11:14 |只看该作者
这样就是对节点自身地址做假设了; 而且, 即便如此, 仍需要第2遍遍历将状态恢复原始状态
zylthinking 发表于 2011-09-22 10:34


内存地址对齐,其实不过分,很多情况下为了提高内存访问效率,都是要对齐的。与树的结构/内容不冲突。
并没有改变树结构,恢复原始状态是什么意思?

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
10 [报告]
发表于 2011-09-22 11:18 |只看该作者
内存地址对齐,其实不过分,很多情况下为了提高内存访问效率,都是要对齐的。与树的结构/内容不冲突。
...
mirnshi 发表于 2011-09-22 11:14


问题是 ”请勿对该树对做任何假设“ , 我说的恢复是状态的恢复, 你总不能这一次修改了状态, 找到后就撒手不管了; 下一次再查找你还怎么修改状态呢, 上一次的状态残留下了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP