LinkedList

一.模拟实现

java 复制代码
public class MyLinkedList {
    static class ListNode {
        private int val;
        private ListNode prev;//前驱
        private ListNode next;//后继

        public ListNode(int val) {
            this.val = val;
        }
    }

    public ListNode head;//双向链表的头节点
    public ListNode last;//双向链表的尾巴

    //得到链表的长度
    public int size(){
        ListNode cur = head;
        int num = 0;
        while (cur != null){
            cur = cur.next;
            num++;
        }
        return num;
    }
    public void display(){
    ListNode cur = head;
    while(cur != null){
        System.out.print(cur.val+" ");
        cur = cur.next;
        }
        System.out.println();
    }

    //查找是否包含关键字key是否在链表当中
    public boolean contains(int key){
        ListNode cur = head;
        while (cur != null){
            if (cur.val == key){
                return true;
            }
            cur = cur.next;
        }
        return false;
    }
    //头插法
    public void addFirst(int data){
    ListNode cur = new ListNode(data);
        if (head == null){
            head = cur;
            last = cur;
        }else {
            cur.next = head;
            head.prev = cur;
            head = cur;
        }
    }

    //尾插法
    public void addLast(int data){
        ListNode cur = new ListNode(data);
        if (head == null){
            head = cur;
            last = cur;
        }else {
            last.next = cur;
            cur.prev = last;
            last = cur;
        }
    }

    //任意位置插入,第一个数据节点为0号下标
    public void addIndex(int index,int data) {
        if (index == 0) {
            addFirst(index);
        } else if (index == size()) {
            addLast(data);
        } else {
            ListNode node = new ListNode(data);
            ListNode sea = searchIndex(index);
            node.next = sea;
            node.prev = sea.prev;
            sea.prev = node;
            node.prev.next = node;
        }
    }

    private ListNode searchIndex(int index) {
            ListNode cur = head;
            if (index < 0 || index >= size()){
                System.out.println("位置不合法");
                return null;
            }
        for (int i = 0; i < index; i++) {
            cur = cur.next;
        }
        return cur;
    }

    private void checkIndex(int index) {

    }


    //删除第一次出现关键字为key的节点
    public void remove(int key){
        ListNode node = head;
        while (node != null){
            if (head.val == key){
                head = head.next;
                if (head != null) {
                    head.prev = null;
                }else {
                    last = null;
                }
                return;
            }else if (node.next == null && last.val == key){
                last = last.prev;
                last.next = null;
                return;
            }else if (node.val == key){
                node.prev.next = node.next;
                node.next.prev = node.prev;
                return;
            }
            node = node.next;
        }
        System.out.println("没有这个");
    }
    //删除所有值为key的节点
    public void removeAllKey(int key){
        ListNode node = head;
        while (node != null){
            if (head.val == key){
                head = head.next;
                if (head != null) {
                    head.prev = null;
                }else {
                    last = null;
                }
            }else if (node.next == null && last.val == key){
                last = last.prev;
                last.next = null;
            }else if (node.val == key){
                node.prev.next = node.next;
                node.next.prev = node.prev;
            }
            node = node.next;
        }
    }

    public void clear(){
        head = null;
        last = null;
    }

    public static void main(String[] args) {
        MyLinkedList myLinkedList = new MyLinkedList();
        myLinkedList.addFirst(1);
        myLinkedList.display();
        myLinkedList.addLast(3);
        myLinkedList.display();
        System.out.println(myLinkedList.size());
        System.out.println(myLinkedList.contains(2));
        System.out.println(myLinkedList.contains(99));
        myLinkedList.addIndex(1, 2);
        myLinkedList.display();
        myLinkedList.remove(2);
        myLinkedList.display();
        myLinkedList.addLast(4);
        myLinkedList.addLast(5);
        myLinkedList.addLast(6);
        myLinkedList.addLast(6);
        myLinkedList.addLast(7);
        myLinkedList.display();
        myLinkedList.remove(1);
        myLinkedList.display();
        myLinkedList.removeAllKey(6);
        myLinkedList.display();
        myLinkedList.clear();
        myLinkedList.addFirst(1);
        myLinkedList.addFirst(1);
        myLinkedList.addFirst(1);
        myLinkedList.addFirst(1);
        myLinkedList.addFirst(1);
        myLinkedList.addFirst(1);
        myLinkedList.addFirst(1);
        myLinkedList.addFirst(1);
        myLinkedList.addFirst(1);
        myLinkedList.addFirst(2);
        myLinkedList.display();
        myLinkedList.remove(1);
        myLinkedList.display();
        myLinkedList.addLast(2);
        myLinkedList.display();
        myLinkedList.remove(2);
        myLinkedList.display();
        myLinkedList.addFirst(2);
        myLinkedList.display();
        myLinkedList.remove(2);
        myLinkedList.display();
        myLinkedList.addFirst(3);
        myLinkedList.addFirst(2);
        myLinkedList.addLast(3);
        myLinkedList.display();
        myLinkedList.remove(3);
        myLinkedList.display();
        myLinkedList.removeAllKey(1);
        myLinkedList.display();
        myLinkedList.clear();
        myLinkedList.display();
        System.out.println(1);

    }
}

二.LinkedList的使用

1.LinkedList的构造

java 复制代码
public class MyLinkedList {
    public static void main(String[] args) {
        //构造一个空的LinkedList
        List<Integer>list1 = new LinkedList<>();

        List<String>list2 = new java.util.ArrayList<>();
        list2.add("haha");
        list2.add("hehe");
        //使用ArrayList构造LinkedList
        List<String>list3 = new LinkedList<>(list2);
    }
}

2.LinkedList的其他常用方法

三.ArrayList和LinkedList的区别

相关推荐
焦耳加热22 分钟前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn30 分钟前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6061 小时前
常用排序算法核心知识点梳理
算法·排序
蒋星熠3 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油4 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream4 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
王璐WL4 小时前
【c++】c++第一课:命名空间
数据结构·c++·算法
空白到白4 小时前
机器学习-聚类
人工智能·算法·机器学习·聚类
索迪迈科技5 小时前
java后端工程师进修ing(研一版 || day40)
java·开发语言·学习·算法
zzzsde5 小时前
【数据结构】队列
数据结构·算法