链表
移除链表元素
题目:
题意:删除链表中等于给定值 val 的所有节点。
示例 1: 输入:head = [1,2,6,3,4,5,6], val = 6 输出:[1,2,3,4,5]
示例 2: 输入:head = [], val = 1 输出:[]
示例 3: 输入:head = [7,7,7,7], val = 7 输出:[]
这里的head指的是链表起始的第一个结构体
说明:链表是一个结构体。对于单向链表来说,结构体里存储了val值和连接的下一个结构体的地址next。对于一个cur链表来说,cur就是这个结构体(一个val,一个next)开辟的首地址,也就是存储val的地址即(&(cur->val))的值,而存储val和next的地址是相连的 ,在结构体开辟的地址之后,即(&(cur->val)和&(cur->)) ; 并且cur->next存放的地址是连接的开辟下一个链表结构体的首地址。
题解:
虚拟头节点:如果第一个元素需要删除,就用到了虚拟头节点
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode* next;
* ListNode() : val(0), next(nullptr) {}
* ListNode(int x) : val(x), next(nullptr) {}
* ListNode(int x, ListNode *next) : val(x), next(next) {}
* };
*/
class Solution {
public:
ListNode* removeElements(ListNode* head, int val) {
ListNode* dummyHead = new ListNode(0);
dummyHead->next = head;
ListNode* cur = dummyHead;
while (cur->next != NULL) {
if (cur->next->val == val) {
// cout<<&(cur->next)<<endl;
// cout<<&(cur->val)<<endl;
ListNode* temp = cur->next;
cur->next = cur->next->next;
delete temp;
} else {
cur = cur->next;
cout << "val" << &(cur->val) << endl;
cout << cur << endl;
cout << "next" << &(cur->next) << endl;
cout << cur->next << endl;
}
}
head = dummyHead->next;
delete dummyHead;
return head;
}
};
标准输出:
val0x502000000050
0x502000000050
next0x502000000058
0x502000000070
val0x502000000070
0x502000000070
next0x502000000078
0x502000000090
val0x5020000000b0
0x5020000000b0
next0x5020000000b8
0x5020000000d0
val0x5020000000d0
0x5020000000d0
next0x5020000000d8
0x5020000000f0
val0x5020000000f0
0x5020000000f0
next0x5020000000f8
0x502000000110
直接使用原来的链表进行移除节点操作:将第一个节点和后面的节点分开计算。
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode() : val(0), next(nullptr) {}
* ListNode(int x) : val(x), next(nullptr) {}
* ListNode(int x, ListNode *next) : val(x), next(next) {}
* };
*/
class Solution {
public:
ListNode* removeElements(ListNode* head, int val) {
while(head!=NULL&&head->val==val)
{
ListNode* temp=head;
head=head->next;
delete temp;
}
ListNode* cur;
cur=head;
while(cur!=NULL&&cur->next!=NULL) // cur如果是一个空指针 或者说cur没有开辟地址内存 那么cur就没有next的内容 就会报错
{
if(cur->next->val==val)
{
ListNode* temp=cur->next;
cur->next=cur->next->next;
delete temp;
}
else{
cur=cur->next;
}
}
return head;
}
};
**注意:**当头链表不是要删除的链表的时候,要判断指针(即开辟链表的首地址)是否为空指针,要是空指针那么空指针中的存放地址的next的查询就会报错。