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

    你可能感兴趣的文章
    Objective-C实现MaximumSubarray最大子阵列(Brute Force蛮力解决方案)算法(附完整源码)
    查看>>
    Objective-C实现MaximumSubarray最大子阵列(动态规划解决方案)算法(附完整源码)
    查看>>
    Objective-C实现maxpooling计算(附完整源码)
    查看>>
    Objective-C实现max_difference_pair最大差异对算法(附完整源码)
    查看>>
    Objective-C实现max_heap最大堆算法(附完整源码)
    查看>>
    Objective-C实现MD5 (附完整源码)
    查看>>
    Objective-C实现md5算法(附完整源码)
    查看>>
    Objective-C实现MeanSquareError均方误差算法 (附完整源码)
    查看>>
    Objective-C实现memcmp函数功能(附完整源码)
    查看>>
    Objective-C实现memoization优化技术算法(附完整源码)
    查看>>
    Objective-C实现memset函数功能(附完整源码)
    查看>>
    Objective-C实现merge insertion sort合并插入排序算法(附完整源码)
    查看>>
    Objective-C实现merge sort归并排序算法(附完整源码)
    查看>>
    Objective-C实现mergesort归并排序算法(附完整源码)
    查看>>
    Objective-C实现miller rabin米勒-拉宾素性检验算法(附完整源码)
    查看>>
    Objective-C实现Miller-Rabin素性测试程序(附完整源码)
    查看>>
    Objective-C实现Miller-Rabin素性测试程序(附完整源码)
    查看>>
    Objective-C实现MinhashLSH算法(附完整源码)
    查看>>
    Objective-C实现MinhashLSH算法(附完整源码)
    查看>>
    Objective-C实现MinHeap最小堆算法(附完整源码)
    查看>>