【leetcode707】设计链表

本文介绍了一种链表的设计方案,实现包括头部插入、尾部插入、指定位置插入、获取节点值及删除节点等功能。通过自定义链表结构,有效地实现了链表的基本操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【leetcode707】设计链表

  • 示例

MyLinkedList linkedList = new MyLinkedList();
linkedList.addAtHead(1);
linkedList.addAtTail(3);
linkedList.addAtIndex(1,2); //链表变为1-> 2-> 3
linkedList.get(1); //返回2
linkedList.deleteAtIndex(1); //现在链表是1-> 3
linkedList.get(1); //返回3

  • 代码
class MyLinkedList {
public:
    MyLinkedList() {
        size = 0;
        head = new LinkNode();
    }

    int get(int index) {
        LinkNode* p = head->next;
        if (index > size - 1 || index < 0 || index>1000) {//如果链表为空,或者index大于链表长度,则访问失败
            return -1;
        }
        while (index--) {
            p = p->next;
        }
        return p->val;

    }

    void addAtHead(int val) {
        if (val < 0 || val>1000) {
            return;
        }
        LinkNode* p = new LinkNode(val, head->next);
        head->next = p;
        size++;
    }

    void addAtTail(int val) {
        if (val < 0 || val>1000) {
            return;
        }
        LinkNode* p = new LinkNode(val);//链表结点
        LinkNode* q = head;//遍历指针
        while (q->next != nullptr) {
            q = q->next;
        }
        q->next = p;
        size++;
    }

    void addAtIndex(int index, int val) {
        if (val < 0 || val>1000 || index > size) {
            return;
        }
        LinkNode* p = new LinkNode(val);
        LinkNode* cur = head;
        while (index--) {
            cur = cur->next;
        }
        size++;
        p->next = cur->next;
        cur->next = p;
    }

    void deleteAtIndex(int index) {
        //根据位序删除元素
        if (index < 0 || index >= size || index > 1000) {
            return;
        }
        LinkNode* p = head;
        while (index--) {
            p = p->next;
        }
        p->next = p->next->next;
        size--;
    }
private:
		//链表结构体
    struct LinkNode {
        int val;
        LinkNode* next;
        LinkNode() :val(0), next(nullptr) {}
        LinkNode(int x) :val(x), next(nullptr) {}
        LinkNode(int x, LinkNode* next) :val(x), next(next) {}
    };
    int size = 0;//链表大小
    LinkNode* head;//虚拟头结点,统一操作,不区分是否头结点
};
  • 执行结果一

在这里插入图片描述biaotifuzhishihaobiaotifuzhishihao
biaotifuzhishihaobiaotifuzhishihao

  • 执行结果二

在这里插入图片描述biaotifuzhishihaobiaotifuzhishihao
biaotifuzhishihaobiaotifuzhishihao

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值