链表
移除链表元素
题目:
题意:删除链表中等于给定值 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的查询就会报错。