C++ Day-4——链表(交换与删除倒数节点)

1.力扣.24 两两交换链表中的节点

https://leetcode.cn/problems/swap-nodes-in-pairs/

题目描述:给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

解题思路:

依旧是首先创建虚拟头节点,然后画图梳理交换各个节点顺序

class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        ListNode* Virtual_head=new ListNode(0);
        Virtual_head->next=head;
        ListNode* cur=Virtual_head;
        while(cur->next!=nullptr&&cur->next->next!=nullptr){
            ListNode* temp1=cur->next;
            ListNode* temp2=cur->next->next->next;
            cur->next=cur->next->next;
            cur->next->next=temp1;
            cur->next->next->next=temp2;
            cur=cur->next->next;
        }
        return Virtual_head->next;

    }
};

需要注意的地方

1.需要创建两个临时指针,第二个指针不创建的话,那么cur->next->next->next指向的位置就不知道了

2.最后返回的是Virtual_head->next

3.在这段代码中,temp1temp2 只是临时指针变量,用于进行节点交换操作。它们并没有使用 new 来动态分配内存,而是直接引用了已经存在于链表中的节点。因此,在交换操作完成后,它们不需要手动释放内存,因为它们没有创建新的动态分配的节点。需要手动释放内存的情况通常是涉及到动态分配的内存(使用了 new 或者类似的内存分配方法)或者容器(如 std::vectorstd::map 等),这些在使用后需要通过 delete 或者容器的析构函数来进行内存释放。但在这个代码中,只是对指针进行了重新赋值,没有分配新的内存空间,所以不需要手动释放。

2.力扣19.删除链表的倒数第N个节点

https://leetcode.cn/problems/remove-nth-node-from-end-of-list/

题目描述:给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

class Solution {
public:
    ListNode* removeNthFromEnd(ListNode* head, int n) {
        ListNode* Virtual_head=new ListNode(0);
        Virtual_head->next=head;
        ListNode* fast = Virtual_head;
        ListNode* slow = Virtual_head;
        while(n-- && fast!=NULL){
            fast=fast->next;
        }
        fast = fast->next;
        while(fast!=NULL){
            fast=fast->next;
            slow=slow->next;
        }
        slow->next=slow->next->next;
        return Virtual_head->next;

    }
};

我所理解的双指针的解题思路:快指针先走n步,这样慢指针就能走到size-n的位置,其实就是利用这个小技巧找到倒数第n个节点,但是删除肯定是删除下一个节点,所以慢指针需要少走一步, 那么慢指针走的步数就是size-n-1,那么快指针走的步数就是n+1步了

进阶:你能尝试使用一趟扫描实现吗?

不能

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值