免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: snowboy9859
打印 上一主题 下一主题

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

论坛徽章:
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
21 [报告]
发表于 2011-09-22 15:14 |只看该作者
1. 足够大是多大???
2. 题目要求可是“节省空间的前提下”

论坛徽章:
0
22 [报告]
发表于 2011-09-22 15:22 |只看该作者
那也简单啊
long nodearray[]; //可以改用链表

while (node1->parent <> root ) || (node2->parent <> root)
{
// 查找 node1->parent 是否在链表内
nodearray【i++】 := node1->parent;

// 查找 node2->parent 是否在链表内
nodearray【i++】 := node2->parent;

node1 = node1->parent;
node2 = node2->parent;

}

论坛徽章:
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
23 [报告]
发表于 2011-09-22 15:28 |只看该作者
唉, 你仔细读帖子看看其他人的方法吧

论坛徽章:
0
24 [报告]
发表于 2011-09-22 15:40 |只看该作者
你们现在要比较节点的深度,这个是不可能的事情,有的节点可能是直接就第2亿个,很深。
我现在的办法,就是把已知的两个节点向上查找,没一个步,多把自己的父节点记录下来,
谁先查找到,与已经记录的节点地址相同,那这个节点就是想通的节点。

我们假设最好的情况,和最差的情况,
最好的情况,就是他们的父节点就是相同,那我只要循环一次就可以了。
最差的情况,就是他们root节点是相同的,那他们一定要循环2亿次。
                  那这个链表就有2亿个节点记录着。

论坛徽章:
0
25 [报告]
发表于 2011-09-22 15:48 |只看该作者
你如果想先求深度的话,假如深度为 2亿,你第一步就死掉了。

论坛徽章:
2
技术图书徽章
日期:2013-09-04 15:21:51酉鸡
日期:2013-11-01 21:20:20
26 [报告]
发表于 2011-09-22 15:50 |只看该作者
你们现在要比较节点的深度,这个是不可能的事情,有的节点可能是直接就第2亿个,很深。
我现在的办法,就是 ...
fanronghua 发表于 2011-09-22 15:40


算法有问题吧,还是没有阐述清楚?

论坛徽章:
0
27 [报告]
发表于 2011-09-22 15:57 |只看该作者
0.开辟一个链表头head。
1.建立两个指针 node1 node2
2.移动node1= node1->parent; 查找 node1 是否在链表内,如果有,找到了,退出,如果没有,插入链表.
   如果为根节点,不做插入动作。
3.nod2做(1)相同的动作。
4.重复 (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
28 [报告]
发表于 2011-09-22 16:01 |只看该作者
你们现在要比较节点的深度,这个是不可能的事情,有的节点可能是直接就第2亿个,很深。
我现在的办法,就是 ...
fanronghua 发表于 2011-09-22 15:40



如果说极限, 那么如果共同父节点是根结点, 根结点右分支只有右分支, 左分支只有左分支, 已知节点分别左分支最后一个及右分支最后一个, 你的办法需要占用多大空间呢???
其实你这个办法就是小狗撒尿算法的一个变形; 而且, 它还不用你那样在链表中一遍遍搜索是否已经命中另一个节点记录的父节点, 而且, 它还不用占用那么大的空间;

至于你说的可能在找到共同父节点后, 仍未搜索到根结点的情况; 小狗撒尿算法也一样能做到的: 就是两支狗同时撒尿同时嗅那种方法。
和比较深度相比, 这个算是优点; 但这个优点也只能在已知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
29 [报告]
发表于 2011-09-22 16:07 |只看该作者
用你的步骤简化的说, 就是:
0.开辟一个链表头head。
1.建立两个指针 node1 node2
2.移动node1= node1->parent; 查找 node1 是否在链表内---》每走一步查找一次, 性能糟糕,如果有,找到了,退出,如果没有,插入链表---》内存占用.
   如果为根节点,不做插入动作。
3.nod2做(1)相同的动作。
4.重复 (2)
fanronghua 发表于 2011-09-22 15:57


所以, 即便不和算深度比, 和小狗撒尿来比, 只有一个优点, 就是不用第二遍遍历, 因为你将状态记录在了链表里, 所以不用走第二遍重置状态; 但和纪录在节点内部方法相比, 似乎不及

论坛徽章:
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
30 [报告]
发表于 2011-09-22 16:10 |只看该作者
你如果想先求深度的话,假如深度为 2亿,你第一步就死掉了。
fanronghua 发表于 2011-09-22 15:48


如果深度2亿, 其他方法至少可以活着计算, 就算花了几百年, 也不会死掉; 而你的照样是2亿, 还背着一个2亿长度的链表, 就算是单链表, 一个存储的节点地址加一个next 指针, 8字节 * 2亿, 是多少???
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP