day3_203移除链表元素_707设计链表_206反转链表

这篇具有很好参考价值的文章主要介绍了day3_203移除链表元素_707设计链表_206反转链表。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

链表理论基础

  1. 链表是一种通过指针串联起的线性结构,每个节点由两部分组成:一个数据域,一个指针域(存放指向下一节点的指针),最后一个节点的指针域指向null。 链表入口节点是头结点head。

    • 双链表:两个指针域,指向下一节点和上一节点。(向前向后查询)day3_203移除链表元素_707设计链表_206反转链表,leetcode,链表,leetcode,c++

    • 循环链表:首尾相连。day3_203移除链表元素_707设计链表_206反转链表,leetcode,链表,leetcode,c++

  2. 存储方式:通过指针,可以散乱的分布数据。

定义链表

手写链表

// 单链表
struct ListNode
{
    int val;        // 节点上存储的元素
    ListNode *next; // 指向下一节点的指针
    ListNide() : val(0), next(NULL){};
    ListNode(int x) : val(x), next(NULL){}; // 节点的构造函数
    ListNide(int x, ListNode *next) : val(x), next(next){};
}// 单链表
struct ListNode
{
    int val;                                // 节点上存储的元素
    ListNode *next;                         // 指向下一节点的指针
    ListNode(int x) : val(x), next(NULL){}; // 节点的构造函数
};

可以不定义构造函数,C++默认生成一个构造函数,但是 这个构造函数不会初始化任何成员变量。

  • ​ 通过自己定义构造函数初始化节点:

    ListNode* head = new LstNode(5);
    
  • 使用默认构造函数初始化节点,如果不定义构造函数,使用默认构造函数的话,在初始化的时候不能直接给变量赋值。

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

链表操作

  1. 删除节点:更改前一节点的next指针指向的位置。在C++中最好再手动释放这个被删除的节点,python,Java就不需要,他们有自己的内存回收机制。
  2. 添加节点:更改前一节点的next指针指向的位置,以及待插入节点next指针指向的位置。
  3. 数组添加/删除O(n),查询O(1);链表插入删除O(1),查询O(n)。

202移除链表元素

203. 移除链表元素 - 力扣(LeetCode)

  1. 定义虚拟头结点dummyHead,遍历节点curr
  2. 删除节点,delete tmp;
/**
 * 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, head);
        ListNode* curr = dummyHead;
        while(curr->next){
            // 考虑curr->next的值
            if(curr->next->val == val){
                ListNode* tmp = curr->next;
                curr->next = tmp->next;
                delete tmp;
            }
            else{
                curr = curr->next;
            }
        
        }
        
        head = dummyHead->next;
        delete dummyHead;
        return head;
    }
};

707设计链表

707. 设计链表 - 力扣(LeetCode)

  1. 构建LinkedNode结构体,设置private初始变量,dummyHead和size
  2. deleteAtIndex和addAtIndex都是遍历pre指针,初始化为dummyHead,pre->next是需要修改的节点。

class MyLinkedList
{

public:
    struct LinkedNode
    {
        int val;
        LinkedNode *next;
        LinkedNode(int val) : val(val), next(nullptr) {}
    };
    // 初始化,设置_dummyHead指针
    MyLinkedList()
    {
        _dummyHead = new LinkedNode(0);
        _size = 0;
    }

    int get(int index)
    {
        if (index > _size - 1 || index < 0)
        {
            return -1;
        }
        LinkedNode *curr = _dummyHead->next;
        for (int currentIndex = 0; currentIndex != index; currentIndex++)
        {
            curr = curr->next;
        }
        return curr->val;
    }

    void addAtHead(int val)
    {
        LinkedNode* newptr = new LinkedNode(val);
        newptr->next = _dummyHead->next;
        _dummyHead->next = newptr;
        _size += 1;
    }

    void addAtTail(int val)
    {
        LinkedNode* newptr = new LinkedNode(val);
        LinkedNode* curr = _dummyHead;
        // 寻找Tail
        while(curr->next != nullptr)
            curr = curr->next;
        curr->next = newptr;
        _size += 1;
    }

    void addAtIndex(int index, int val)
    {
        if (index > _size || index < 0)
        {
            return ;
        }
        LinkedNode *newptr = new LinkedNode(val);
        LinkedNode *pre = _dummyHead;
        for (int currentIndex = 0; currentIndex < index; currentIndex++)
        {
            pre = pre->next;
        }
        newptr->next = pre->next;
        pre->next = newptr;
        _size += 1;
    }

    void deleteAtIndex(int index)
    {
        if (index > _size - 1 || index < 0)
        {
            return ;
        }
        LinkedNode *pre = _dummyHead;
        for (int currentIndex = 0; currentIndex < index; currentIndex++)
            pre = pre->next;
        LinkedNode *tmp = pre->next;
        pre->next = tmp->next;
        delete tmp;
        tmp = nullptr;
        _size -= 1;
    }
    void printLinkedList() {
        LinkedNode* cur = _dummyHead;
        while (cur->next != nullptr) {
            cout << cur->next->val << " ";
            cur = cur->next;
        }
        cout << endl;
    }
private:
    int _size;
    LinkedNode* _dummyHead;

};

/**
 * Your MyLinkedList object will be instantiated and called as such:
 * MyLinkedList* obj = new MyLinkedList();
 * int param_1 = obj->get(index);
 * obj->addAtHead(val);
 * obj->addAtTail(val);
 * obj->addAtIndex(index,val);
 * obj->deleteAtIndex(index);
 */

206反转链表

Loading Question… - 力扣(LeetCode)

day3_203移除链表元素_707设计链表_206反转链表,leetcode,链表,leetcode,c++

  1. 首先定义一个cur指针,指向头结点,**再定义一个pre指针,初始化为null。**不断移动即可。
/**
 * 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* reverseList(ListNode* head) {
        ListNode* curr = head;
        ListNode* pre = nullptr;

        while(curr){
            ListNode* tmp = curr->next;
            curr->next = pre;
            pre = curr;
            curr = tmp;
        }
        return pre;

    }
};

curr = head;
ListNode* pre = nullptr;

    while(curr){
        ListNode* tmp = curr->next;
        curr->next = pre;
        pre = curr;
        curr = tmp;
    }
    return pre;

}

};文章来源地址https://www.toymoban.com/news/detail-593421.html




到了这里,关于day3_203移除链表元素_707设计链表_206反转链表的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • day 3 | 203.移除链表元素、707.设计链表、206.反转链表

    目录: 链表基础:https://programmercarl.com/链表理论基础.html 题目链接: https://leetcode.cn/problems/remove-linked-list-elements/ 203. 移除链表元素 给你一个链表的头节点  head  和一个整数  val  ,请你删除链表中所有满足  Node.val == val  的节点,并返回  新的头节点  。 自己思路:从头

    2024年02月08日
    浏览(43)
  • Day 3 链表: 203.移除链表元素, 707.设计链表, 206.反转链表

    链接基础,以及链表和数组的区别: 代码随想录 1. 链表类型: 单列表,双列表,循环列表。 单列表: 双列表: 循环列表: 2. 链表的操作 :删除节点,增加节点。 删除节点: 其中对于 普通的节点 删除,就如上图所示,直接让前一个节点的指向下一个节点即可。 但是对于

    2024年02月16日
    浏览(41)
  • Day03|链表01:203.移除链表元素、707.设计链表、206.反转链表

    今天进入链表章节的学习了,也是之前学过的内容,这次争取快速AC。 leetcode链接:https://leetcode.cn/problems/remove-linked-list-elements/ 没什么好说的,这里注意引入了一个虚拟头节点dummy,这样就不用处理需要删除第一个节点的特殊情况。删除时C++需要手动detete。我本来使用free的,

    2024年02月17日
    浏览(42)
  • 【Leetcode60天带刷】day03链表——203. 移除链表元素,707.设计链表,206. 反转链表

    链表就像一串小火车,有一节一节的车厢,每个车厢都叫做一个节点。  单链表:每个链表车厢里有两个内容,一个放的是真正的数据,另一个放的是下一节车厢的编号。 双链表:每个链表车厢里有三个内容,一个真正数据,一个下一个车厢的编号,还有一个上一节车厢的编

    2024年02月06日
    浏览(48)
  • 复习Day05:链表part01:203.移除链表元素、707.设计链表、206.反转链表、234. 回文链表

    之前的blog链接:https://blog.csdn.net/weixin_43303286/article/details/131700482?spm=1001.2014.3001.5501 我用的方法是在leetcode再过一遍例题,明显会的就复制粘贴,之前没写出来就重写,然后从拓展题目中找题目来写。辅以Labuladong的文章看。然后刷题不用CLion了,使用leetcode自带模拟面试环境。

    2024年02月07日
    浏览(37)
  • 刷题日记 Day 3 : Leetcode 203 . 移除链表元素、Leetcode 707 . 设计链表、Lettcode 206 . 反转链表

    本篇文章 , 是在代码随想录 60 天编程挑战的基础上进行的题目讲解 参与链接在此 : https://programmercarl.com/other/xunlianying.html 大家好 , 这个专栏 , 给大家带来的是 60 天刷题强训 . 最令大家头疼的事就是刷题了 , 题目又臭又长又抽象 , 有的题读都读不懂 , 更别说做了 . 所以 , 这个

    2023年04月09日
    浏览(50)
  • 203.移除链表元素&707.设计链表& 206.反转链表

    203.移除链表元素: 给你一个链表的头节点  head  和一个整数  val  ,请你删除链表中所有满足  Node.val == val  的节点,并返回  新的头节点  。 707.设计链表  : 你可以选择使用单链表或者双链表,设计并实现自己的链表。 单链表中的节点应该具备两个属性:val 和 next 。

    2024年02月11日
    浏览(34)
  • 203.移除链表元素|707.设计链表|206.反转链表

    203. 移除链表元素 这里以链表 1 4 2 4 来举例,移除元素4。 如果使用C,C++编程语言的话,不要忘了还要从内存中删除这两个移除的节点, 清理节点内存之后如图: 其实 可以设置一个虚拟头结点 ,这样原链表的所有节点就都可以按照统一的方式进行移除了。 来看看如何设置

    2024年02月11日
    浏览(41)
  • 算法训练第三天|203.移除链表元素、707.设计链表、206.反转链表

    题目链接:力扣 思路:删除链表元素与数组不同之处在于,它需要被删除链表元素的前一个元素和后一个元素的参与,而不需要其他元素的参与。 我们使被删除元素前一个元素的指针指向被删除元素的后一个元素 ,也就是直接跳过被删除的元素,来实现删除。 同时我们考

    2024年02月05日
    浏览(38)
  • 【代码随想录刷题记录】 203.移除链表元素 、 707.设计链表 、206.反转链表

    题目 给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。 题目链接:https://leetcode.cn/problems/remove-linked-list-elements/ 代码 小结 该题主要注意链表删除的操作以及在特殊情况下如何进行操作。特殊情况包括头结点为目标

    2024年02月08日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包