[Leetcode]删除链表中等于val 的所有结点
创始人
2024-06-02 08:40:56
0

力扣链接

方法一:

使用前后两个指针,cur指向当前位置,prev指向前一个位置,通过改变指向和释放结点来删除val

初步代码,还存在问题:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/struct ListNode* removeElements(struct ListNode* head, int val)
{struct ListNode* prev = NULL;struct ListNode* cur = head;while(cur){if(cur->val != val){prev = cur;cur = cur->next;}else{prev->next = cur->next;free(cur);// cur = cur->next;//错误,cur已经被释放,野指针cur = prev->next;}}return head;}

null pointer出现了空指针

通过测试用例代码走读分析问题:

如果第一个就是要删的值,也就是头删,会出现问题

所以这种情况要单独处理

最终代码:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/struct ListNode* removeElements(struct ListNode* head, int val)
{struct ListNode* prev = NULL;struct ListNode* cur = head;while(cur){if(cur->val != val){prev = cur;cur = cur->next;}else{if(prev == NULL){head = cur->next;free(cur);cur = head;}else{prev->next = cur->next;free(cur);//cur = cur->next;//和下一句等价,但是cur已经释放,这句会出现野指针cur = prev->next;}}}return head;//返回一个新的头,不需要用二级指针}

方法二:

把不是val的值尾插到新链表

初步代码:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/struct ListNode* removeElements(struct ListNode* head, int val)
{struct ListNode* newHead= NULL,* tail = NULL;struct ListNode* cur = head;while(cur){if(cur->val != val){//尾插if(tail == NULL){newHead = tail = cur;}else{tail->next = cur;tail = tail->next;}cur = cur->next;}else{struct ListNode* next = cur->next;free(cur);cur = next;}}return newHead;
}

通过走读代码我们发现,当最后一个结点的值为val时,释放节点后前面尾插的结点仍然指向最后一个结点,这里只需要将tail->next置空即可,修改后代码如下:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/struct ListNode* removeElements(struct ListNode* head, int val)
{struct ListNode* newHead= NULL,* tail = NULL;struct ListNode* cur = head;while(cur){if(cur->val != val){//尾插if(tail == NULL){newHead = tail = cur;}else{tail->next = cur;tail = tail->next;}cur = cur->next;}else{struct ListNode* next = cur->next;free(cur);cur = next;}}tail->next = NULL;return newHead;
}

但是代码仍然存在错误,运行如下:

显而易见,需要考虑链表为空的情况

改进后代码:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/struct ListNode* removeElements(struct ListNode* head, int val)
{if(head== NULL){return NULL;}struct ListNode* newHead= NULL,* tail = NULL;struct ListNode* cur = head;while(cur){if(cur->val != val){//尾插if(tail == NULL){newHead = tail = cur;}else{tail->next = cur;tail = tail->next;}cur = cur->next;}else{struct ListNode* next = cur->next;free(cur);cur = next;}}tail->next = NULL;return newHead;
}

报错:

这时代码直接指向最后一个else,此时tail为空,tail->next不合理,所以干脆前面不进行判断,而在后面对tail进行判断

最终代码如下:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/struct ListNode* removeElements(struct ListNode* head, int val)
{struct ListNode* newHead= NULL,* tail = NULL;struct ListNode* cur = head;while(cur){if(cur->val != val){//尾插if(tail == NULL){newHead = tail = cur;}else{tail->next = cur;tail = tail->next;}cur = cur->next;}else{struct ListNode* next = cur->next;free(cur);cur = next;}}if(tail){tail->next = NULL;}return newHead;
}

相关内容

热门资讯

“全国低碳日” 共赴绿色新程 (转自:运城新闻网)1公里以内步行,3公里以内骑车,5公里以内乘公交低碳出行,共赴绿色新程□记者 祁...
我的铁路风景|万里云“途”开,... 美好旅途,文化相伴旅途中,我们邂逅了许多美丽瞬间广大旅客、网友用镜头、画笔、文字勾勒出文化中国的美丽...
博士后当交警,为啥? 冬日,京郊,岔路口,几名交警聚在道路中间部位。其中一位身量不高、戴着眼镜的交警,在清扫过积雪的一片区...
为什么幸运大转盘,转来转去到是... 为什么幸运大转盘,转来转去到是“谢谢参与”和“财富值”都是这些。其他的没有。不要泄气我刚才就中了那个...
镁伽科技拟赴港上市,业绩连年亏... 6月25日,镁伽科技有限公司向港交所提交上市申请。招股书显示,镁伽科技是机器人技术应用领域领先的自主...
A股全市场超3600只个股上涨... 6月27日,市场早盘震荡分化,三大指数涨跌不一。沪深两市半日成交额9913亿,较上个交易日放量138...
上海发布高温橙色预警 部分地区... 经济观察网讯 据央视新闻客户端消息,上海中心气象台6月27日11时12分更新高温黄色预警为高温橙色预...
美国通用家电投资4.9 亿美元... 青岛日报社/观海新闻6月27日讯 2025 年6月26日,海尔智家旗下通用家电公司宣布,将在位于肯塔...
京东外卖:布局政企服务市场 覆... 转自:证券时报人民财讯6月27日电,6月27日,记者从公司方面获悉,京东外卖正在布局政企服务市场,已...
小动物的特征 小动物的特征小白兔的特征有耳朵,眼,鼻,四肢。特点是胆小,骤惊。外貌特点耳朵:长而大,甚至可超过头的...