707.设计链表

2023-06-28  本文已影响0人  xxttw
image.png

思路

int size;
    ListNode dummyHead;
    public MyLinkedList() {

        size = 0;
        dummyHead = new ListNode(-1);
    }
    //get(index):获取链表中第 index 个节点的值。如果索引无效,则返回-1。
    public int get(int index) {
        if (index < 0 || index >= size) return -1;

        ListNode cur = dummyHead.next;
        while (index -- > 0) {
            cur = cur.next;
        }

        return cur.val;
    }

   // addAtHead(val):在链表的第一个元素之前添加一个值为 val 的节点。插入后,新节点将成为链表的第一个节点。
    public void addAtHead(int val) {
        ListNode node = new ListNode(val, dummyHead.next);
        dummyHead.next = node;
        size++;
    }

    //addAtTail(val):将值为 val 的节点追加到链表的最后一个元素。
    public void addAtTail(int val) {
        ListNode cur = dummyHead;
        while (cur.next != null) {
            cur = cur.next;
        }
        ListNode node = new ListNode(val, null);
        cur.next = node;
        size++;
    }
    //addAtIndex(index,val):在链表中的第 index 个节点之前添加值为 val  的节点。
    //如果 index 等于链表的长度,则该节点将附加到链表的末尾。如果 index 大于链表长度,则不会插入节点。如果index小于0,则在头部插入节点。
    public void addAtIndex(int index, int val) {
        if (index > size) return;
        if (index < 0) {
            index = 0;
        }

        ListNode cur = dummyHead;
        while (index -- > 0) {
            cur = cur.next;
        }
        ListNode node = new ListNode(val, cur.next);
        cur.next = node;
        size++;

    }
   // deleteAtIndex(index):如果索引 index 有效,则删除链表中的第 index 个节点。

    public void deleteAtIndex(int index) {
        if (index < 0 || index >= size) return;
        ListNode cur = dummyHead;
        while (index -- > 0) {
            cur = cur.next;
        }
        cur.next = cur.next.next;
        size--;
    }
上一篇 下一篇

猜你喜欢

热点阅读