【代码随想录刷题记录】24 两两交换链表中的节点、19 删除链表的倒数第n个节点 、面试题 02.07. 链表相交、142 环形链表||

这篇具有很好参考价值的文章主要介绍了【代码随想录刷题记录】24 两两交换链表中的节点、19 删除链表的倒数第n个节点 、面试题 02.07. 链表相交、142 环形链表||。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

  1. 题目
    给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。
    题目链接:https://leetcode.cn/problems/swap-nodes-in-pairs/

  2. 代码文章来源地址https://www.toymoban.com/news/detail-500999.html

class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        ListNode *_head = new ListNode();//虚拟头结点,统一操作
        _head -> next = head;
        //需要用到的指针
        ListNode *prep, *p, *q, *nexq;//p,q为需要交换的两个节点,prep为p的前驱,nexq为q的后继
        prep = _head;
        p = head;
        //遍历
        while(p != nullptr && p -> next != nullptr){//还剩一个的情况不进行操作 
            q = p -> next;
            nexq = q -> next;
            //交换
            prep -> next = q;
            q -> next = p;
            p -> next = nexq;
            //遍历
            prep = p;
            p = nexq;
        }
        head = _head -> next;
        return head;
    }
};
  1. 小结
    使用虚拟头结点统一头结点交换的特殊情况,根据交换使用多个指针避免链表出现断链的情况,注意有奇数个结点或偶数个结点的链表在结尾的不同操作。

19 、删除链表的倒数第n个节点

  1. 题目
    给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。
    题目链接:https://leetcode.cn/problems/remove-nth-node-from-end-of-list/

  2. 代码

class Solution {
public:
    ListNode* removeNthFromEnd(ListNode* head, int n) {
        //构建虚拟头结点
        ListNode * _head = new ListNode();
        _head -> next = head;
        //定义需要的指针
        ListNode *p, *q;//p用于指向删除结点的前驱,q用于定位删除的结点
        p = _head;
        q = _head;
        //找到p与q之间的位置关系;
        while(n != 0 && q!= nullptr){
            q = q -> next;
            n--;
        }
        if(q == nullptr) return head;
        //找到目标结点的前驱
        while(q -> next != nullptr){
            p = p -> next;
            q = q -> next;
        }
        //删除操作
        q = p -> next;
        p -> next = q -> next;
        delete q;
        
        head = _head -> next;
        delete _head;
        
        return head;
    }
};
  1. 小结
    使用双指针的方法,确定删除的目标结点的前驱与尾结点之间的距离。使用p、q,先将q单独遍历直到p、q之间的距离符合目标结点的前驱与尾结点之间的距离时,将p 、q同时遍历,直到q到达为尾结点时,p在的位置就是目标结点的前驱,此时只需要进行删除操作就可以了。该方法的时间复杂度就为O(n)。需要特别注意若删除的结点是头结点时,可以采用虚拟头结点的方法统一操作。

面试题 02.07. 链表相交

  1. 题目
    给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。
    题目链接:https://leetcode.cn/problems/intersection-of-two-linked-lists-lcci/
  2. 代码
class Solution {
public:
    ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) {
        //相关变量
        int na = 0, nb = 0, n = 0;//na-a链表长度,nb为b链表长度,n为两链表长度差值
        ListNode *pa, *pb;//pa-遍历a链表、pb遍历b链表
        
        //a\b链表空的情况
        if(headA == NULL || headB == NULL) return NULL;

        //其他情况
        pa = headA;
        pb = headB;

        //求链表长度
        while(pa != NULL){
            na++;
            pa = pa -> next;
        }
        while(pb != NULL){
            nb++;
            pb = pb -> next;
        }

        if(na >= nb) n = na - nb;
        else n = nb -na;


        //对齐链表尾
        pa = headA;
        pb = headB;
        while(n != 0){
            if(na > nb) pa = pa -> next;
            else pb = pb -> next;
            n--;
        }

        //遍历找交点
        while(pa != pb && pa != NULL && pb != NULL){
            pa = pa -> next;
            pb = pb -> next;
        }

        //没有交点
        if(pa == NULL || pb == NULL) return NULL;
        else  return pa;

    }
};
  1. 小结
    本题思路与上题相似,都是需要对齐队尾元素然后进行遍历找到相同的结点,时间复杂度为o(n)。

142 、环形链表||

  1. 题目
    给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。
    如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。如果 pos 是 -1,则在该链表中没有环。注意:pos 不作为参数进行传递,仅仅是为了标识链表的实际情况。
    不允许修改 链表。
    题目链接:https://leetcode.cn/problems/linked-list-cycle-ii/

  2. 代码

class Solution {
public:
    ListNode *detectCycle(ListNode *head) {
        //相关变量
        ListNode *slow = head;
        ListNode *fast = head;
        //判断是否有环
        while(fast != NULL && fast->next != NULL) {
            slow = slow->next;
            fast = fast->next->next;
            // 快慢指针相遇,
            if (slow == fast) {
                ListNode* index1 = fast;
                ListNode* index2 = head;
                while (index1 != index2) {
                    index1 = index1->next;
                    index2 = index2->next;
                }
                return index2; // 返回环的入口
            }
        }
        return NULL;
    }
};
  1. 小结
    使用双指针法,重点理解为何存在环时,fast和slow为何一定在环内相遇,以及一个从相遇点走和一个从头结点走,为何相遇点是环的入口。若存在环,fast永远比slow多走一步,当slow进入环内,fast会以每次一格结点的速度最终追上slow。当slow与fast相遇时,fast的经过的结点数是slow的两倍,也就是说一个从相遇点,一个从头结点以相同速度出发最终会从环的入口开始相遇并同步前进。

到了这里,关于【代码随想录刷题记录】24 两两交换链表中的节点、19 删除链表的倒数第n个节点 、面试题 02.07. 链表相交、142 环形链表||的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 代码随想录Day4:24. 两两交换链表中的节点,19.删除链表的倒数第N个节点 ,面试题 02.07. 链表相交 ,142.环形链表II

    题目要求:  使用虚拟头节点,代码实现: 题目要求: 我的思路: 先通过while语句找出整体链表的size,再算出要删除结点前一个结点的索引。 更简单(更妙)的方法:快慢指针法 代码实现: 题目要求: 看到题目自己首先的想法就是暴力搜索,但是会做很多不必要的遍历。

    2024年02月20日
    浏览(41)
  • 代码随想录第四天|LeetCode24. 两两交换链表中的节点,LeetCode19.删除链表的倒数第N个节点,LeetCode面试题 02.07. 链表相交,LeetCode142.环形链表II

    LeetCode24. 两两交换链表中的节点 题目链接:24. 两两交换链表中的节点 - 力扣(LeetCode) 思路: 先定义一个虚拟头结点方便操作。 再就是交换相邻两个元素了, 此时一定要画图,不画图,操作多个指针很容易乱,而且要操作的先后顺序 初始时,cur指向虚拟头结点,然后进行

    2024年02月09日
    浏览(40)
  • 【代码随想录 | Leetcode | 第六天】链表 | 反转链表 | 两两交换链表中的节点 | 删除链表的倒数第 N 个结点

    欢迎来到小K的Leetcode|代码随想录|专题化专栏,今天将为大家带来反转链表、两两交换链表中的节点和删除链表的倒数第N个节点的分享 ✨ ✨题目链接点这里 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 示例 1: 示例 2: 示例 3: 提示: 链表中节点的数

    2024年02月16日
    浏览(58)
  • 代码随想录刷题第4天|LeetCode24、LeetCode19、LeetCode160、LeetCode142

    1、LeetCode24 两两交换链表中的节点 题目链接:24、两两交换链表中的节点 要想清楚终止条件,cur每次指向要交换的两个节点的前一个节点,cur = cur-next-next; 若链表元素个数为偶数 , 则最后时刻 cur-next = NULL; 若链表元素个数为奇数,则最后时刻 cur-next-next = NULL; 最后要返回

    2024年02月05日
    浏览(47)
  • 【代码随想录刷题记录】 392.判断子序列 、 115.不同的子序列

    1、题目 给定字符串 s 和 t ,判断 s 是否为 t 的子序列。 字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,\\\"ace\\\"是\\\"abcde\\\"的一个子序列,而\\\"aec\\\"不是)。 题目链接:https://leetcode.cn/problems/is-subsequence/ 2、代码

    2024年02月16日
    浏览(44)
  • 【代码随想录刷题记录】 203.移除链表元素 、 707.设计链表 、206.反转链表

    题目 给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。 题目链接:https://leetcode.cn/problems/remove-linked-list-elements/ 代码 小结 该题主要注意链表删除的操作以及在特殊情况下如何进行操作。特殊情况包括头结点为目标

    2024年02月08日
    浏览(47)
  • 代码随想录刷题

    704. 二分查找 27. 移除元素

    2024年01月25日
    浏览(50)
  • 【代码随想录】刷题Day47

    198. 打家劫舍 1.dp数组含义:dp[i]为i位置下的最大能得到的价值 2.根据条件:相邻不能偷。i位置的最大价值取决于i-1位置是否已经偷过了。如果偷过了,i位置的最大价值就是dp[i-1],即i位置的物品不偷;如果没有偷过,i位置的最大价值就是dp[i-2]+nuvms[i],i位置的数和对应的d

    2024年02月07日
    浏览(48)
  • 【代码随想录】刷题Day41

    343. 整数拆分 1.dp数组的含义:第i个就表示当前i能被拆分出相乘最大的整数 2.那么其实,所谓的后续的i对应的相乘最大整数其实就是前面的相乘最大整数拼凑而成,为了更好的区分我们将分离出来的数为j,那么我们的工作就是将一个又一个的j从i中剥离出,随后相乘即可。那

    2024年02月07日
    浏览(46)
  • 【代码随想录】刷题Day35

    860. 柠檬水找零 1.如果第一个顾客没有五元,那么直接返回false,因为店主开始没有零钱 2.定义两个int,一个记录5元,一个记录10元,随后遍历整个数组,会出现三种情况: 如果顾客给5元,直接num5加一 如果顾客给10元,判断num5是否大于0,大于则num5--,num10++;反之返回false

    2024年02月06日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包