面试总结

本文探讨了如何判断两个单链表是否存在交叉及其交叉点的确定方法,并介绍了从一百万个数中高效筛选出100个最大数值的技术方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题一:怎么判断两个单链表是否有交叉

这个问题只问了有没有交叉而没有问给出交叉点是谁。

所以只需要两个链表走到最后的位置判断是否相等就可以知道有没有交叉了。

问题二:有一百万个数,要从里面获取100个最大的数?

使用冒泡,最外层循环100次就可以找到100个最大的数。

选择排序和这个也很像。

最好的方法是用堆来实现,建一个有100个节点的小根堆,比根节点大就和根节点替换然后重构小根堆,如果比根节点小,就不要这个数。

问题三:怎么判断两个单链表是否有交叉,并得到交叉点?

一种方法是,遍历两个单链表,获取他们的长度,然后较长的先走相差的那几步,然后两个同时开始走,判断是否相等,若相等则是交叉点,停止。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值