203. 移除链表元素

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == 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
输出:[]

提示:

列表中的节点数目在范围 [0, 104] 内
1 <= Node.val <= 50
0 <= val <= 50


 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* current = head;  //令当前节点为头节点

        while (current != nullptr) //当前节点不为空
        {
	        if (current->next != nullptr && current->next->val == val)//下一节点不为空且下一节点的值为val需要删掉
	        {
                current->next = current->next->next; // 更新下一节点
	        }else
	        {
                current = current->next; //更新当前节点,若当前节点为尾节点,结束判断,若下一节点不需要删掉,则继续循环进行判断
	        }
        }

        if (head != nullptr && head->val == val) //最后判断头节点
        {
            return head->next; //如果头节点值和给定值相等,删掉头节点
        }else
        {
            return head; //头节点为空,返回空链表,头节点不为空且值不等于给定值,返回更新后的链表
        }
     }
 };


//原来的啰嗦写法
 class Solution {
 public:
     ListNode* removeElements(ListNode* head, int val) {
	    //从头节点开始,判断头节点是否为空,空值直接返回head
	    //链表不为空,则将头节点设为当前节点,判断当前节点下一节点是否为空
	    //如果为空,结束循环,判断头节点是否为给定值,不是的话返回head,是的话返回空链表
	    //如果不为空,判断下一节点的值是否为给定值,是给定值,判断下一节点的下一节点是否为空,空
	    //为空:将当前节点指向空指针,判断头节点是否为给定值,不是的话返回head,是的话返回空链表
	    //不为空:将下一节点的下一节点 更新为 当前节点的下一节点,在判断当前节点的下一节点是否为给定值 
	    // 是给定值,重复38,不是给定值,更新当前节点,判断当前节点的下一节点是否为空,重复37,38
	    //直到判断完所有的,判断头节点的值,不是就返回head,等于val则更新头节点返回新链表
         ListNode* current_node = head;
         if (head == nullptr)
             return head;
         else
         {
             for (current_node; current_node != nullptr;)
             {
                 if (current_node->next == nullptr)
                 {
                     if (head->val == val)
                         return head = head->next;
                     else
                         return head;
                 }
                 else
                 {
                     if ((current_node->next)->val == val)   // 如果当前节点的的下一个节点等于这个值
                     {
                         if ((current_node->next)->next != nullptr) //下一节点的下一节点 不为空
                         {
                             current_node->next = (current_node->next)->next;  //更新下一节点 
                         }
                         else  //下一节点即为最后一个节点
                         {
                             current_node->next = nullptr;  //删掉最后一个节点,当前节点变为最后一个节点
                         }

                     }
                    else
                    {
                         current_node = current_node->next;  //只有值不等时才更新当前节点
                    }
                 }

             }
         }
             return head;
     }
 };


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是链表元素的Python代码: ```python class ListNode: def __init__(self, val=0, next=None): self.val = val self.next = next def removeElements(head: ListNode, val: int) -> ListNode: # 处理头部节点为要删除元素的情况 while head is not None and head.val == val: head = head.next # 处理链表中间节点为要删除元素的情况 if head is not None: node = head while node.next is not None: if node.next.val == val: node.next = node.next.next else: node = node.next return head ``` 这里定义了一个ListNode类表示链表节点,其中val表示节点的值,next表示指向下一个节点的指针。removeElements函数的第一个参数head表示链表的头节点,第二个参数val表示要删除的元素值。函数的返回值是除后的链表头节点。 函数的实现分为两步: 1. 处理头部节点为要删除元素的情况,即如果头部节点的值等于要删除的元素值,则将头部节点指向下一个节点,直到头部节点的值不等于要删除的元素值。 2. 处理链表中间节点为要删除元素的情况,即从头节点开始遍历链表,如果当前节点的下一个节点的值等于要删除的元素值,则将当前节点的next指针指向下一个节点的next指针,即跳过当前节点的下一个节点;否则,将当前节点指向下一个节点。遍历完成后,返回链表的头节点。 注意,这里的实现并没有考虑链表为空的情况,需要在调用函数前进行判断。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值