707 设计链表——dummyHead好用

我算是知道dummyHead虚假头节点的妙处了,addAtHead的时候,不用判断链表是否为空,直接把新节点往dummyHead后面一连就可以

注意链表的长度要实时更新!

class MyLinkedList {
private:
    ListNode* _dummyHead;
    int _size;
public:
    //创建一个空链表,把成员变量初始化一下
    MyLinkedList() {
        _dummyHead = new ListNode(0);
        _size = 0;//链表的长度记得要实时更新!
    }
    
    int get(int index) {
        if((index < 0) || (index >= _size)) return -1;
        ListNode* cur = _dummyHead;
        //假设索引为3,dum 0 1 2 3,要找4次,cur成为我们要的节点
        for(int i = 0; i <= index; i++) {
            cur = cur->next;
        }
        return cur->val;
    }
    
    void addAtHead(int val) {
        ListNode* newNode = new ListNode(val);
        newNode->next = _dummyHead->next;
        _dummyHead->next = newNode;
        _size++;//增加节点,链表长度更新
    }
    
    void addAtTail(int val) {
        ListNode* cur = _dummyHead;
        while(cur->next != nullptr) {
            cur = cur->next;
        }
        ListNode* newNode = new ListNode(val);
        cur->next = newNode;
        _size++;
    }
    
    void addAtIndex(int index, int val) {
        if(index > _size) return;
        else if(index == _size) {
            addAtTail(val); return;
        }
        else if(index == 0) {
            addAtHead(val); return;
        } else {
            ListNode* cur = _dummyHead;
            while(index--) {
                cur = cur->next;
            }
            ListNode* newNode = new ListNode(val);
            newNode->next = cur->next;
            cur->next = newNode;
            _size++;
        }
    }
    
    void deleteAtIndex(int index) {
        if((index < 0) || (index >= _size)) return;
        ListNode* cur = _dummyHead;
        while(index--) {
            cur = cur->next;
        }
        ListNode* tem = cur->next;
        cur->next = cur->next->next;
        delete tem;
        _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);
 */

相关推荐

  1. 707 设计——dummyHead

    2024-02-19 07:46:01       49 阅读
  2. leetcode707.设计

    2024-02-19 07:46:01       59 阅读
  3. 【Leetcode】707. 设计

    2024-02-19 07:46:01       68 阅读
  4. LeetCode:707. 设计

    2024-02-19 07:46:01       56 阅读
  5. 707.设计(力扣LeetCode)

    2024-02-19 07:46:01       58 阅读
  6. 力扣 设计707

    2024-02-19 07:46:01       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-19 07:46:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-19 07:46:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-19 07:46:01       87 阅读
  4. Python语言-面向对象

    2024-02-19 07:46:01       96 阅读

热门阅读

  1. Effective Objective-C 学习(四)

    2024-02-19 07:46:01       41 阅读
  2. vscode创建vue项目的方法

    2024-02-19 07:46:01       51 阅读
  3. xtu oj 1150 n!进制 2.0

    2024-02-19 07:46:01       49 阅读
  4. 【c/c++】C++静态工具类和单例模式对比学习

    2024-02-19 07:46:01       52 阅读
  5. 12.20 校招 实习 内推 面经

    2024-02-19 07:46:01       52 阅读
  6. pytorch chunk的使用举例

    2024-02-19 07:46:01       51 阅读
  7. 记录 | pytorch计算ap的方法

    2024-02-19 07:46:01       52 阅读
  8. 深度学习:开启人工智能的未来探索之旅

    2024-02-19 07:46:01       57 阅读
  9. leetcode热题100. 字母异位词分组

    2024-02-19 07:46:01       54 阅读