代码随想录-DAY③-链表——leetcode 203 | 707 | 206

203

思路

设置一个虚拟头结点,这样所有节点就都可以按照统一的方式进行移除。

如果下一个节点的值等于 val,让节点 next 指针直接指向下下一个节点。

不要忘记清理节点内存。

时间复杂度: O(n)

空间复杂度: O(1)

代码
cpp 复制代码
/**
 * 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* dumphead = new ListNode(0, head);
        ListNode* pre = dumphead;

        while(pre->next != nullptr){
            if(pre->next->val == val){
                ListNode* tmp = pre->next;
                pre->next = pre->next->next;
                delete tmp;
            }
            else{
                pre = pre->next;
            }
        }
        head = dumphead->next;
        delete dumphead;
        return head;
    }
};

707

思路

addAtHead(val) 和 addAtTail(val) 可以借助 addAtIndex(index, val) 来实现

根据题意,优先判断 index 的有效性

使用虚拟头结点和变量size记录节点数

时间复杂度:get O(index),addAtHead O(1),addAtTail O(n),addAtIndex O(index),deleteAtIndex O(index)

空间复杂度:单函数 O(1),总体 O(n)

代码
cpp 复制代码
class MyLinkedList {
public:
    MyLinkedList() {
        dummyhead = new ListNode(0);
        size = 0;
    }
    
    int get(int index) {
        ListNode* getnode = dummyhead;
        if(index<0 || index>=size){
            return -1;
        }
        for(int i=0; i<=index; i++){
            getnode = getnode->next;
        }
        return getnode->val;
    }
    
    void addAtHead(int val) {
        return addAtIndex(0, val);
    }
    
    void addAtTail(int val) {
        return addAtIndex(size, val);
    }
    
    void addAtIndex(int index, int val) {
        ListNode* node = dummyhead;
        if(index>size){
            return;
        }
        index = max(0,index);
        for(int i=0; i<index; i++){
            node = node->next;
        }
        ListNode* newnode = new ListNode(val);
        newnode->next = node->next;
        node->next = newnode;
        size++;
    }
    
    void deleteAtIndex(int index) {
        ListNode* node = dummyhead;
        if(index<0 || index>=size){
            return;
        }
        for(int i=0; i<index; i++){
            node = node->next;
        }
        ListNode* tmp = node->next;
        node->next = node->next->next;
        delete tmp;
        size--;
    }

private:
    ListNode* dummyhead;
    int size;
};

/**
 * 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

思路

在遍历链表时,将当前节点的 next 指针改为指向前一个节点。由于节点没有引用其前一个节点,因此必须事先存储其前一个节点。在更改引用之前,还需要存储后一个节点。最后返回新的头引用。

时间复杂度: O(n)

空间复杂度: O(1)

代码
cpp 复制代码
/**
 * 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 *pre = nullptr, *cur = head, *temp;

        while(cur != nullptr){
            temp = cur->next;
            cur->next = pre;
            pre = cur;
            cur = temp;
        }
        return pre;
    }
};
相关推荐
ZZZ_O^O27 分钟前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
CV-King1 小时前
opencv实战项目(三十):使用傅里叶变换进行图像边缘检测
人工智能·opencv·算法·计算机视觉
代码雕刻家1 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
雨中rain1 小时前
算法 | 位运算(哈希思想)
算法
Kalika0-03 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
代码雕刻家3 小时前
课设实验-数据结构-单链表-文教文化用品品牌
c语言·开发语言·数据结构
sp_fyf_20243 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-02
人工智能·神经网络·算法·计算机视觉·语言模型·自然语言处理·数据挖掘
小字节,大梦想4 小时前
【C++】二叉搜索树
数据结构·c++
我是哈哈hh5 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
Tisfy5 小时前
LeetCode 2187.完成旅途的最少时间:二分查找
算法·leetcode·二分查找·题解·二分