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.在这段代码中,temp1
和 temp2
只是临时指针变量,用于进行节点交换操作。它们并没有使用 new
来动态分配内存,而是直接引用了已经存在于链表中的节点。因此,在交换操作完成后,它们不需要手动释放内存,因为它们没有创建新的动态分配的节点。需要手动释放内存的情况通常是涉及到动态分配的内存(使用了 new
或者类似的内存分配方法)或者容器(如 std::vector
、std::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步了
进阶:你能尝试使用一趟扫描实现吗?
不能