• 链表的注意事项


    LeetCode 19 删除链表的倒数第N个结点

    1、sudo.next = head;和head = sudo.next; 的区别?

    他们是不一样的,前者是将head赋给sudo.next,而后者是将sudo.next赋给head。

    首先a=b,那么b必须存在

    我想要将sudo作为虚拟头节点,并且指向head

    那么是将head赋给sudo.next,所以是sudo.next = head;

    head = sudo.next;的话,sudo.next是为空(新建一个ListNode,会创建一个值为0的头节点,然后指向空)

    2、虚拟头节点的作用

    其实不止一次接触到这个虚拟头节点,但是每次都容易忘记它的作用

    其实就是为了简化头节点的处理逻辑(但是这道题还有一个有意思的点就是我需要让快指针比慢指针快n+1步,如果不设置虚拟头节点的话,特殊情况n=链表长度下,也就是删除头节点,我们让快慢指针开始都指向head,那么就会造成null.next的现象)

    3、return sudo.next;和return head;的区别?

    假设我需要删除的是头节点,n=链表长度,在low.next=low.next.next;时

    此时low=sudo,那么sudo.next=sudo.next.next;

    改变的是sudo.next,而不是head

    如果return head那么会是原来的结果...(但是奇怪的是为什么head居然还有值?可能在单向链表中其实是可以两个节点指向同一个节点的,意思就是每个节点的next是唯一的,但是他的前置节点不一定是唯一的)

    1. class Solution {
    2. public ListNode removeNthFromEnd(ListNode head, int n) {
    3. ListNode sudo = new ListNode();
    4. sudo.next = head;
    5. ListNode fast = new ListNode();
    6. ListNode low = new ListNode();
    7. fast = sudo;
    8. low = sudo;
    9. for(int i=0;i<n+1;i++) {
    10. fast = fast.next;
    11. }
    12. while(fast != null) {
    13. fast = fast.next;
    14. low = low.next;
    15. }
    16. low.next = low.next.next;
    17. return sudo.next;
    18. //return head; //错误
    19. }
    20. }

  • 相关阅读:
    Neuron v2.2.2 发布:MQTT插件功能提升 、新增OPC DA驱动
    C语言:用函数指针实现加减乘除的应用
    Vue中的Ajax①(配置代理)
    2021 RoboCom 世界机器人开发者大赛-本科组(初赛)
    网易笔试8.20
    Unity编辑器扩展
    上海移动HG6145D光猫之超级用户登录方法
    LVGL---进度条(lv_bar)
    【linux】进程创建,进程终止
    二叉树(堆)
  • 原文地址:https://blog.csdn.net/weixin_43582743/article/details/133474053