六六力扣刷题链表之移除链表元素

简介: 六六力扣刷题链表之移除链表元素

前言

之前小六六一直觉得自己的算法比较菜,算是一个短板吧,以前刷题也还真是三天打鱼,两台晒网,刷几天,然后就慢慢的不坚持了,所以这次,借助平台的活动,打算慢慢的开始开刷,并且自己还会给刷的题总结下,谈谈自己的一些思考,和自己的思路等等,希望对小伙伴能有所帮助吧,也可以借此机会把自己短板补一补,希望自己能坚持下去呀

贪心

数组

链表

今天开始,我们来做几个链表的题目吧

题目

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点

输入: head = [1,2,6,3,4,5,6], val = 6
输出: [1,2,3,4,5]

image.png

解析

链表的定义具有递归的性质,因此链表题目常可以用递归的方法求解。这道题要求删除链表中所有节点值等于特定值的节点,可以用递归实现。

public ListNode1 removeElements(ListNode1 head, int val) {
    if (head==null){
        return head;
    }
    head.next = removeElements(head.next, val);
    return head.val == val ? head.next : head;
}

也可以用迭代的方法删除链表中所有节点值等于特定值的节点。

public ListNode1 removeElements1(ListNode1 head, int val) {
    if (head==null){
        return new ListNode1();
    }
    ListNode1 dummyHead = new ListNode1(0);
    dummyHead.next=head;
    ListNode1 temp=dummyHead;
    while (temp.next!=null){
        if (temp.next.val==val){
            temp.next=temp.next.next;
        }else {
            temp=temp.next;
        }
    }
    return  dummyHead.next;
}

其实我觉得吧,做链表的题目,其实也不是很难,难的是我们的不知道怎么去定义临时节点,在node.next.next中迷路

  • 直接使用原来的链表来进行删除操作。
  • 设置一个虚拟头结点在进行删除操作。

大家最好断点去理解下链表吧

结束

链表的提,其实也不是那么难,但是大家还是要多学习下,多断点去理解!

相关文章
|
1天前
|
算法 C语言
Leetcode_203.移除链表元素—C语言
Leetcode_203.移除链表元素—C语言
|
2天前
|
人工智能
力扣100114. 元素和最小的山形三元组 II(中等)
力扣100114. 元素和最小的山形三元组 II(中等)
|
7天前
|
存储
力扣 合并两个有序数列||移除元素
力扣 合并两个有序数列||移除元素
11 0
|
8天前
leetcode代码记录(下一个更大元素 II
leetcode代码记录(下一个更大元素 II
10 0
|
8天前
|
索引
leetcode代码记录(下一个更大元素 I
leetcode代码记录(下一个更大元素 I
9 0
|
8天前
|
算法 C++
【刷题】Leetcode 1609.奇偶树
这道题是我目前做过最难的题,虽然没有一遍做出来,但是参考大佬的代码,慢慢啃的感觉的真的很好。刷题继续!!!!!!
12 0
|
8天前
|
算法 索引
【刷题】滑动窗口精通 — Leetcode 30. 串联所有单词的子串 | Leetcode 76. 最小覆盖子串
经过这两道题目的书写,相信大家一定深刻认识到了滑动窗口的使用方法!!! 下面请大家继续刷题吧!!!
16 0
|
8天前
|
算法
【刷题】 leetcode 面试题 08.05.递归乘法
递归算法是一种在计算机科学和数学中广泛应用的解决问题的方法,其基本思想是利用问题的自我相似性,即将一个大问题分解为一个或多个相同或相似的小问题来解决。递归算法的核心在于函数(或过程)能够直接或间接地调用自身来求解问题的不同部分,直到达到基本情况(也称为基础案例或终止条件),这时可以直接得出答案而不必再进行递归调用。
28 4
【刷题】 leetcode 面试题 08.05.递归乘法
|
8天前
|
存储 算法 安全
【刷题】 leetcode 面试题 01.06 字符串压缩
来看效果: 非常好!!!过啦!!!
30 5
【刷题】 leetcode 面试题 01.06 字符串压缩