免费注册 查看新帖 |

Chinaunix

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

Oracle面试题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-11-29 10:45 |只看该作者 |倒序浏览
昨天去oracle面试,阿三出了道面试题,
在此分享给各位,以集思广益:

写一个函数,判断两个链表是否相交,若相交,返回交点,不相交,返回NULL。
  1. sNode * intersect(sNode *a,sNode *b)
  2. {
  3. ...
  4. }
复制代码
要求:不许创建新的链表,尽量的少占内存,时间复杂度尽量小。


Ps:奶奶的,最悲剧的是,面试全程英文,阿三还有很浓的印度口音,听的太累。做出来后,还要用英文讲思路。擦。。。


有好方法的请下面跟帖...~

论坛徽章:
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
2 [报告]
发表于 2011-11-29 11:02 |只看该作者
这个不就是一个两步一跳, 一个一步一跳的思路吗?
至于找到交点, 看http://bbs.chinaunix.net/redirec ... 81&ptid=3598431

论坛徽章:
1
CU十二周年纪念徽章
日期:2013-10-24 15:41:34
3 [报告]
发表于 2011-11-29 11:05 |只看该作者

论坛徽章:
0
4 [报告]
发表于 2011-11-29 11:16 |只看该作者
这个不就是一个两步一跳, 一个一步一跳的思路吗?
至于找到交点, 看
zylthinking 发表于 2011-11-29 11:02



    不错。~{:2_171:}

论坛徽章:
1
技术图书徽章
日期:2013-09-17 09:11:51
5 [报告]
发表于 2011-11-29 11:29 |只看该作者
关于链表的面试题有很多,可以去搜一下。
由于两个链表相交只能是Y型相交。所以一般的情况是判断最后的节点是否一样。但是还有一种情况是当一个链表的最后一个节点和另一个链表的任意节点相交时就不能只判断最后的节点了。

可以先算出两个链表的长度,然后以这个步长|L1 - L2| 来进行链表的比较:比如L2为短的,则L1链表以步长|L1 - L2|移动,L2以步长1移动。 判断两个链表的节点何时相等即可。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP