博客
关于我
在单链表和双链表中删除倒数第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/

    你可能感兴趣的文章
    opencv 模板匹配, 已解决模板过大程序不工作的bug
    查看>>
    OpenCV 错误:(-215)size.width>0 &&函数imshow中的size.height>0
    查看>>
    opencv&Python——多种边缘检测
    查看>>
    opencv&python——高通滤波器和低通滤波器
    查看>>
    OpenCV+Python识别车牌和字符分割的实现
    查看>>
    OpenCV-Python接口、cv和cv2的性能比较
    查看>>
    OpenCV/Python/dlib眨眼检测
    查看>>
    opencv1-加载、修改、保存图像
    查看>>
    opencv10-形态学操作
    查看>>
    opencv11-提取水平直线和垂直直线
    查看>>
    opencv12-图像金字塔
    查看>>
    opencv13-基本阈值操作
    查看>>
    opencv14-自定义线性滤波
    查看>>
    opencv15-边缘处理
    查看>>
    opencv16-Sobel算子
    查看>>
    opencv17-laplance算子
    查看>>
    opencv18-canny检测算法
    查看>>
    opencv19-霍夫直线变化
    查看>>
    opencv2-矩阵掩膜操作
    查看>>
    opencv20-霍夫圆检测
    查看>>