代码随想录算法训练营第四天 | 24. 两两交换链表中的节点、19.删除链表的倒数第N个节点、面试题 02.07. 链表相交、142.环形链表II

24. 两两交换链表中的节点

题目链接/文章讲解/视频讲解: 代码随想录

(1)思路总结     -cur指向需要交换2个节点的前一个

(2)代码

 19.删除链表的倒数第N个节点  --快慢双指针,fast先走n+1步

题目链接/文章讲解/视频讲解:代码随想录

(1)思路总结

(2)代码

 

面试题 02.07. 链表相交

题目链接/文章讲解:代码随想录

(1)答疑

问:[4,1,8,4,5]和[5,0,1,8,4,5]的相交节点为什么不是1?

答:该题交点不是数值相等,而是指针相等!注意是指针哦!

假设指针P1指向[4,1,8,4,5]里的1,地址是001。

假设指针P2指向[5,0,1,8,4,5]里的1,地址是002。

虽然两个指针指向的节点值相同,但是地址不同,所以这并不是同一个节点,也就不是题目的交点。

      为什么 [4,1,8,4,5] [5,0,1,8,4,5] 是从8开始相交而不是从1开始相交呢?看了大多数评论都说比较的是指针地址是否相等? 那为什么两个8的指针就相等,两个1的指针就不相等呢? 点击右侧代码块下面的控制台->填入示例->示例1->测试用例 ,可以看见

       

      此时点击 执行代码将得到“Intersected at '8'”, 如果将最后两行改成

      此时点击执行代码将得到“Intersected at '1'”,也就是从1开始相等,真相大白了,原来从1还是8开始是根据题目输入的intersectVal、skipA、skipB自己决定的,因此我们只需要按照逻辑写代码就好。 

(2)代码

 

 142.环形链表II  

题目链接/文章讲解/视频讲解:代码随想录

(1)思路总结

 

(2)代码

 

其他补充

  1. ListNode dummy=new ListNode(-1,head);   直接将虚拟头节点的next设为head

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值