首页 > 编程语言 >代码随想录算法训练营第三天|203.移除链表元素,707.设计链表,206.反转链表

代码随想录算法训练营第三天|203.移除链表元素,707.设计链表,206.反转链表

时间:2024-10-18 22:01:42浏览次数:1  
标签:head ListNode cur val self 随想录 next 链表 移除

1 前言

  1. 今日主要学习链表的基础
  2. leetcode 203移除链表元素
  3. leetcode 707 设计链表
  4. leetcode 206 反转链表

2 链表的基础

  1. 链表分为单链表和双链表,与字符串的区别就是链表是在一个里面存储了数据+下一个数据的内存地址
  2. 链表中存储的内存空间是可以不连续的

2.1 链表的定义

2.1.1 python版本
class ListNode:
    def __init__(self,val=0,next=None):
        self.val = val
        self.next = next
2.1.2 C++版本

单链表自己构造并定义的方法

struct ListNode{
    int val;
    ListNode *next;
    ListNode(int x):val(x),next(Null) {}
};
ListNode*head =new ListNode(5)

默认构造的方法

ListNode *head = new ListNode();
head -->val = 5;

3 leetcode203 移除链表元素

题目链接:203. 移除链表元素 - 力扣(LeetCode)

文章链接:代码随想录 (programmercarl.com)

视频链接:帮你把链表操作学个通透!LeetCode:707.设计链表_哔哩哔哩_bilibili

思路:没有思路,看到这道题有一种想立马退出的感觉,无从下手

3.1 原来链表进行删除的方法

自己是完全敲不出来的那种,真的听了课程也没有跟上的章节

3.1.1 python方法

这个版本是参考了C++语法,自己改过来的版本

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def removeElements(self, head: Optional[ListNode], val: int) -> Optional[ListNode]:
        while head!=None and head.val == val:
            head = head.next
        cur = head
        while cur!=None and cur.next !=None:
            if cur.next.val == val:
                cur.next = cur.next.next
            else:
                cur=cur.next
        return head
3.1.2 C++方法
/**
 * 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* tmp = head;
            head = head->next;
            delete tmp;
        }   
        ListNode* cur = head;
        while (cur!=NULL && cur->next!=NULL){
            if (cur->next->val == val){
                ListNode* tmp = cur->next;
                cur->next = cur->next->next;
                delete tmp;
            }
            else{
                cur=cur->next;
            }
        }
        return head;
    }
};

3.2 新建一个虚拟头结点进行删除

3.2.1 python版本
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def removeElements(self, head: Optional[ListNode], val: int) -> Optional[ListNode]:
        dummy_head = ListNode(next=head)
        cur = dummy_head
        while cur.next !=None:
            if cur.next.val==val:
                cur.next=cur.next.next
            else:
                cur=cur.next
        return dummy_head.next
3.2.2 C++版本
/**
 * 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){
                ListNode* tmp = cur->next;
                cur->next = cur->next->next;
                delete tmp;
            }
            else{
                cur = cur->next;
            }
        }
        head = dummyHead->next;
        delete dummyHead;
        return head;
    }

3.3单链表小结

  1. 这一部分首先就是需要了解链表是什么,其实链表逻辑就是链表存储的是数字加下一个元素的位置
  2. 单链表就是从前往后走不会回头的那种所以就不会存在我下一个数值和上一个的联系

4 leetcode707设计链表

题目链接:707. 设计链表 - 力扣(LeetCode)

文章链接:代码随想录 (programmercarl.com)

视频链接:帮你把链表操作学个通透!LeetCode:707.设计链表_哔哩哔哩_bilibili

思路:压根不会,看了视频也没有学会的一道题

4.1 单链表的方法

4.1.1 python版本
class ListNode:
    def __init__(self,val=0,next=None):
        self.val = val
        self.next = next
class MyLinkedList:

    def __init__(self):
        self.dummy_head = ListNode()
        self.size = 0 

    def get(self, index: int) -> int:
        if index<0 or index>=self.size:
            return -1

        current = self.dummy_head.next
        for i in range(index):
            current = current.next
        return current.val

    def addAtHead(self, val: int) -> None:
        self.dummy_head.next = ListNode(val,self.dummy_head.next)
        self.size +=1

    def addAtTail(self, val: int) -> None:
        current = self.dummy_head
        while current.next:
            current = current.next
        current.next = ListNode(val)
        self.size +=1

    def addAtIndex(self, index: int, val: int) -> None:
        if index<0 or index>self.size:
            return
        current = self.dummy_head
        
        for i in range(index):
            current = current.next
        current.next = ListNode(val,current.next)
        self.size +=1    

    def deleteAtIndex(self, index: int) -> None:
        if index<0 or index>=self.size:
            return

        current = self.dummy_head
        for i in range(index):
            current = current.next
        current.next = current.next.next
        self.size -=1
        


# Your MyLinkedList object will be instantiated and called as such:
# obj = MyLinkedList()
# param_1 = obj.get(index)
# obj.addAtHead(val)
# obj.addAtTail(val)
# obj.addAtIndex(index,val)
# obj.deleteAtIndex(index)

4.2 链表设计小结

这一道题是真的好难,完全没有思路的那种,对着别人的思路进行复现了一下,然后理解了别人里面的基本逻辑,但是具体的,怎么说呢,还是得明天复习,发现从这一章开始变难了,我只能先完成python版本的了,C++等二刷的时候,我再去重新学习重新写吧

5 leetcode206.反转链表

5.1 双指针的方法

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def reverseList(self, head: Optional[ListNode]) -> Optional[ListNode]:
        pre = None
        current = head
        while current:
            tmp = current.next
            current.next = pre
            pre = current
            current = tmp
        return pre

5.2递归思想

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def reverseList(self, head: Optional[ListNode]) -> Optional[ListNode]:
        return self.reverse(None,head)
    def reverse(self,pre:ListNode,cur:ListNode)->ListNode:
        if cur == None:
            return pre
        temp = cur.next
        cur.next = pre
        return self.reverse(cur,temp)

5.3 小结

这一部分的递归思想我听懂了,但是代码实现过程中,其实很绕很绕还是不是很会写

6.总结

6.1 代码总结

  1. 主要就是调用链表中的存储位置是humlenth.next
  2. 调用链表中的值是humlenth.next.val
  3. python方法定义一个链表的代码是
class ListNode():
    __init__(self,val=0,next=None):
        self.val = val
        self.next = next

6.2方法思路总结

  1. 首先注意链表其实是一个给定的值和存储空间用一根线连接的,所以在使用链表的时候就是注意他的值和存储空间即head的位置
  2. 其实现在回想这几道题,思路其实挺清晰的就是不会写,嗯,递归的方法等周末有时间了还得复习,写的真的不是很好

标签:head,ListNode,cur,val,self,随想录,next,链表,移除
From: https://www.cnblogs.com/csfy0524/p/18475129

相关文章

  • 代码随想录算法训练营 | 115.不同的子序列,583. 两个字符串的删除操作,72. 编辑距离
    115.不同的子序列题目链接:115.不同的子序列文档讲解︰代码随想录(programmercarl.com)视频讲解︰不同的子序列日期:2024-10-18想法:dp[i][j]表示以s[i-1],t[j-1]结尾的s,t自学列中满足s的子序列为t的个数,如果s[i-1],t[j-1]相等,那么个数应该跟双方上一个结尾状态dp[i-1][j-......
  • 83. 删除排序链表中的重复元素 线性法&快慢双指针
    83.删除排序链表中的重复元素给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。示例1:输入:head=[1,1,2]输出:[1,2]示例2:输入:head=[1,1,2,3,3]输出:[1,2,3]提示:链表中节点数目在范围 [0,300] 内-100<=......
  • 109. 有序链表转换二叉搜索树【二叉树】
    文章目录109.有序链表转换二叉搜索树解题思路Go代码109.有序链表转换二叉搜索树109.有序链表转换二叉搜索树给定一个单链表的头节点head,其中的元素按升序排序,将其转换为平衡二叉搜索树。平衡二叉树是指该树所有节点的左右子树的深度相差不超过1。示例......
  • 力扣面试题02.07.链表相交
    题目链接:面试题02.07.链表相交-力扣(LeetCode)给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。图示两个链表在节点 c1 开始相交:题目数据 保证 整个链式结构中不存在环。注意,函数返回结果......
  • 力扣142.环形链表II
    题目链接:142.环形链表II-力扣(LeetCode)给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。为了表示给定链表中的环,评测系统内部使用整数 pos 来表示......
  • 代码随想录算法训练营 | 1143.最长公共子序列,1035.不相交的线,53. 最大子序和,392.判断
    1143.最长公共子序列题目链接:1143.最长公共子序列文档讲解︰代码随想录(programmercarl.com)视频讲解︰最长公共子序列日期:2024-10-17想法:这里的子序列不要求连续了,dp[i][j]要表示为在text1[0,i-1]和text2[0,j-1]的范围里,最长的公共子序列长度,-1同样是为了初始化方便,如果te......
  • 【数据结构】之链表详解
    链表是一种常用的数据结构,它是一种线性数据结构,但与数组不同,它并非连续存储数据,而是通过指针将数据节点连接起来。每个节点都包含数据域和指向下一个节点的指针域。这种结构赋予链表独特的优势和局限性,使其在某些场景下优于数组,在另一些场景下则相对逊色。本文将深入探讨链表,包......
  • 翻转链表常用写法
    翻转链表常用写法循环写法classSolution{public:ListNode*reverseList(ListNode*head){ListNode*prev=nullptr,*next=nullptr,*now=head;while(now){next=now->next;now->next=prev;prev=......
  • 代码随想录算法训练营第二天|209长度最小的子数组、59螺旋矩阵
    1leetcode209长度最小的子数组题目链接:209.长度最小的子数组文章链接:代码随想录(programmercarl.com)视频链接:拿下滑动窗口!|LeetCode209长度最小的子数组思路:没有思路,看到这道题有一种想立马退出的感觉,无从下手1.1暴力搜索1.1.1python版本这个版本的新知识就是定义......
  • 24. 两两交换链表中的节点
    给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。示例1:输入:head=[1,2,3,4]输出:[2,1,4,3]示例2:输入:head=[]输出:[]示例3:输入:head=[1]输出:[1]解题思路:1.递归方法实现节点对的交换......