博客
关于我
在单链表和双链表中删除倒数第K个节点
阅读量:401 次
发布时间:2019-03-05

本文共 1780 字,大约阅读时间需要 5 分钟。

删除链表中的倒数第K个节点

在编程中,链表的操作是一个非常基础但重要的技能。以下,我们将分别实现两个函数:一个用于删除单链表中倒数第K个节点,另一个用于删除双链表中倒数第K个节点。

单链表删除倒数第K个节点

public static Node removeLastKthNode(Node head, int lastKth) {    if (head == null || lastKth < 1) {        return head;    }    Node cur = head;    // 第一遍遍历,计算总长度    while (cur != null) {        lastKth--;        cur = cur.next;    }    // 如果lastKth大于链表长度,直接返回头节点    if (lastKth > 0) {        return head;    }    // 如果lastKth为0,删除最后一个节点    if (lastKth == 0) {        return head.next;    }    // 一般情况,删除倒数第K个节点    cur = head;    while (++lastKth != 0) {        cur = cur.next;    }    cur.next = cur.next.next;    return head;}

双链表删除倒数第K个节点

public static DoubleNode removeLastKthNode(DoubleNode head, int lastKth) {    if (head == null || lastKth < 1) {        return head;    }    DoubleNode cur = head;    // 第一遍遍历,计算总长度    while (cur != null) {        lastKth--;        cur = cur.next;    }    // 如果lastKth大于链表长度,直接返回头节点    if (lastKth == 0) {        head = head.next;        head.last = null;        return head;    }    // 如果lastKth大于链表长度,直接返回头节点    if (lastKth > 0) {        return head;    }    // 一般情况,删除倒数第K个节点    cur = head;    while (++lastKth != 0) {        cur = cur.next;    }    DoubleNode nextNode = cur.next;    cur.next = nextNode;    if (nextNode != null) {        nextNode.last = cur;    }    return head;}

代码解释

单链表删除函数

  • 初始检查:首先检查链表是否为空或lastKth小于1,如果是,直接返回头节点。
  • 计算链表长度:通过遍历链表,计算链表的总长度,并更新lastKth的值。
  • 处理特殊情况
    • 如果lastKth大于链表长度,直接返回头节点。
    • 如果lastKth等于0,删除最后一个节点。
  • 删除倒数第K个节点:从头节点开始遍历,直到找到需要删除的节点,并调整指针。
  • 双链表删除函数

  • 初始检查:与单链表删除函数类似,首先检查链表是否为空或lastKth小于1。
  • 计算链表长度:同样通过遍历链表,计算链表的总长度。
  • 处理特殊情况
    • 如果lastKth等于0,删除最后一个节点,并重置last指针。
    • 如果lastKth大于链表长度,直接返回头节点。
  • 删除倒数第K个节点:从头节点开始遍历,找到需要删除的节点,并调整前后节点的指针。
  • 总结

    这些函数通过两次遍历链表,分别实现了删除单链表和双链表中倒数第K个节点的功能。需要注意的是,在双链表中,删除节点时需要同时处理前后节点的指针,确保链表的完整性。

    转载地址:http://xuczz.baihongyu.com/

    你可能感兴趣的文章
    Regular Expression Notes
    查看>>
    PHP $FILES error码对应错误信息
    查看>>
    PHP $_FILES函数详解
    查看>>
    PHP $_SERVER['HTTP_REFERER'] 获取前一页面的 URL 地址
    查看>>
    php &amp; 和 &amp;amp; (主要是url 问题)
    查看>>
    php -- 魔术方法 之 判断属性是否存在或为空:__isset()
    查看>>
    php -- 魔术方法 之 获取属性:__get()
    查看>>
    php -树-二叉树的实现
    查看>>
    PHP -算法-二路归并
    查看>>
    php 2条不一样 的json数据 怎么放在一个json里面_如果你是PHP开发者,请务必了解一下Composer...
    查看>>
    php 360 不记住密码,JavaScript_多种方法实现360浏览器下禁止自动填写用户名密码,目前开发一个项目遇到一个很 - phpStudy...
    查看>>
    regExp的match、exec、test区别
    查看>>
    php 404 自定义,APACHE 自定义404错误页面设置方法
    查看>>
    PHP 5.3.0以上推荐使用mysqlnd驱动
    查看>>
    php aes sha1解密,PHP AES加密/解密
    查看>>
    php CI框架单个file表单多文件上传例子
    查看>>
    php composer
    查看>>
    reflow和repaint引发的性能问题
    查看>>
    php csv 导出
    查看>>
    php curl 实例+详解
    查看>>