链表相关知识整理

一、知识点梳理

 

 

 

 

 二、主要代码

1.单向链表

package p2.动态链表;

import p1.接口.List;

import java.util.Comparator;
import java.util.Iterator;

public class LinkedSinglyList<E> implements List<E> {


    @Override
    public void add(E element) {

    }

    @Override
    public void add(int index, E element) {

    }

    @Override
    public void remove(E element) {

    }

    @Override
    public E remove(int index) {
        return null;
    }

    @Override
    public E get(int index) {
        return null;
    }

    @Override
    public E set(int index, E element) {
        return null;
    }

    @Override
    public int size() {
        return 0;
    }

    @Override
    public int indexOf(E element) {
        return 0;
    }

    @Override
    public boolean contains(E element) {
        return false;
    }

    @Override
    public boolean isEmpty() {
        return false;
    }

    @Override
    public void clear() {

    }

    @Override
    public void sort(Comparator<E> c) {

    }

    @Override
    public List<E> subList(int fromIndex, int toIndex) {
        return null;
    }

    @Override
    public Iterator<E> iterator() {
        return null;
    }
}

2.双向循环链表

package part02;

import java.util.Comparator;
import java.util.Iterator;

import 数据结构接口.Dequeue;
import 数据结构接口.List;
import 数据结构接口.Stack;

public class LinkedList<E> implements List<E> , Dequeue<E> , Stack<E> {
	 private class Node {
	        E data;
	        Node pre;   //直接前驱
	        Node next;  //直接后继

	        public Node() {
	            this(null, null, null);
	        }

	        public Node(E data) {
	            this(data, null, null);
	        }

	        public Node(E data, Node pre, Node next) {
	            this.data = data;
	            this.pre = pre;
	            this.next = next;
	        }

	        @Override
	        public String toString() {
	            return data.toString();
	        }
	    }

	    private Node head;
	    private Node tail;
	    private int size;

	    public LinkedList() {
	        head = null;
	        tail = null;
	        size = 0;
	    }

	    public LinkedList(E[] arr) {
	        if (arr == null) {
	            throw new IllegalArgumentException("arr can not be null");
	        }
	        for (E e : arr) {
	            add(e);
	        }
	    }

	    @Override
	    public void add(E element) {
	        add(size, element);
	    }

	    @Override
	    public void add(int index, E element) {
	        if (index < 0 || index > size) {
	            throw new IllegalArgumentException("add index out of range");
	        }
	        Node n = new Node(element);
	        if (size == 0) {
	            head = n;
	            tail = n;
	            tail.next = head;
	            head.pre = tail;
	        } else if (index == 0) {
	            n.pre = head.pre;
	            n.next = head;
	            head.pre = n;
	            head = n;
	            tail.next = head;
	        } else if (index == size) {
	            n.next = tail.next;
	            tail.next = n;
	            n.pre = tail;
	            tail = n;
	            head.pre = tail;
	        } else {
	            Node p, q;
	            if (index <= size / 2) {
	                p = head;
	                for (int i = 0; i < index - 1; i++) {
	                    p = p.next;
	                }
	                q = p.next;
	                p.next = n;
	                n.pre = p;
	                q.pre = n;
	                n.next = q;
	            } else {
	                p = tail;
	                for (int i = size - 1; i > index; i--) {
	                    p = p.pre;
	                }
	                q = p.pre;
	                q.next = n;
	                n.pre = q;
	                n.next = p;
	                p.pre = n;
	            }
	        }
	        size++;
	    }

	    @Override
	    public void remove(E element) {
	        int index = indexOf(element);
	        if (index != -1) {
	            remove(index);
	        }
	    }

	    @Override
	    public E remove(int index) {
	        if (index < 0 || index >= size) {
	            throw new IllegalArgumentException("remove index out of range");
	        }
	        E ret = null;
	        Node node;
	        if (size == 1) {
	            ret = head.data;
	            head = null;
	            tail = null;
	        } else if (index == 0) {
	            ret = head.data;
	            node = head.next;
	            head.next = null;
	            node.pre = head.pre;
	            head.pre = null;
	            head = node;
	            tail.next = head;
	        } else if (index == size - 1) {
	            ret = tail.data;
	            node = tail.pre;
	            tail.pre = null;
	            node.next = tail.next;
	            tail.next = null;
	            tail = node;
	            head.pre = tail;
	        } else {
	            Node p, q, r;
	            if (index <= size / 2) {
	                p = head;
	                for (int i = 0; i < index - 1; i++) {
	                    p = p.next;
	                }
	                q = p.next;
	                r = q.next;
	                ret = q.data;
	                p.next = r;
	                r.pre = p;
	                q.next = null;
	                q.pre = null;
	            } else {
	                p = tail;
	                for (int i = size - 1; i > index + 1; i--) {
	                    p = p.pre;
	                }
	                q = p.pre;
	                r = q.pre;
	                ret = q.data;
	                r.next = p;
	                p.pre = r;
	                q.next = null;
	                q.pre = null;
	            }
	        }
	        size--;
	        return ret;
	    }

	    @Override
	    public E get(int index) {
	        if (index < 0 || index >= size) {
	            throw new IllegalArgumentException("get index out of range");
	        }
	        if (index == 0) {
	            return head.data;
	        } else if (index == size - 1) {
	            return tail.data;
	        } else {
	            Node p = head;
	            for (int i = 0; i < index; i++) {
	                p = p.next;
	            }
	            return p.data;
	        }
	    }

	    @Override
	    public E set(int index, E element) {
	        if (index < 0 || index >= size) {
	            throw new IllegalArgumentException("set index out of range");
	        }
	        E ret = null;
	        if (index == 0) {
	            ret = head.data;
	            head.data = element;
	        } else if (index == size - 1) {
	            ret = tail.data;
	            tail.data = element;
	        } else {
	            Node p = head;
	            for (int i = 0; i < index; i++) {
	                p = p.next;
	            }
	            ret = p.data;
	            p.data = element;
	        }
	        return ret;
	    }

	    @Override
	    public int size() {
	        return size;
	    }

	    @Override
	    public int indexOf(E element) {
	        Node p = head;
	        int index = 0;
	        while (!p.data.equals(element)) {
	            p = p.next;
	            index++;
	            if (p == head) {
	                return -1;
	            }
	        }
	        return index;
	    }

	    @Override
	    public boolean contains(E element) {
	        return indexOf(element) != -1;
	    }


	    @Override
	    public boolean isEmpty() {
	        return size == 0 && head == null && tail == null;
	    }


	    @Override
	    public void clear() {
	        head = null;
	        tail = null;
	        size = 0;
	    }

	    @Override
	    public void sort(Comparator<E> c) {
	        if (c == null) {
	            throw new IllegalArgumentException("comparator can not be null");
	        }
	        //插入排序来做
	        if (size == 0 || size == 1) {
	            return;
	        }
	        for (Node nodeA = head.next; nodeA != head; nodeA = nodeA.next) {
	            E e = nodeA.data;
	            Node nodeB;
	            Node nodeC;
	            for (nodeB = nodeA, nodeC = nodeB.pre; nodeC != tail && c.compare(nodeC.data, e) > 0; nodeB = nodeB.pre, nodeC = nodeC.pre) {
	                nodeB.data = nodeC.data;
	            }
	            nodeB.data = e;
	        }
	    }

	    @Override
	    public List<E> subList(int fromIndex, int toIndex) {
	        if (fromIndex < 0 || toIndex >= size || fromIndex > toIndex) {
	            throw new IllegalArgumentException("0 <= fromIndex <= toIndex < size");
	        }
	        Node nodeA = head;
	        for (int i = 0; i < fromIndex; i++) {
	            nodeA = nodeA.next;
	        }
	        Node nodeB = head;
	        for (int i = 0; i < toIndex; i++) {
	            nodeB = nodeB.next;
	        }
	        Node p = nodeA;
	        LinkedList<E> list = new LinkedList<>();
	        while (true) {
	            list.add(p.data);
	            if (p == nodeB) {
	                break;
	            }
	            p = p.next;
	        }
	        return list;
	    }

	    @Override
	    public String toString() {
	        StringBuilder sb = new StringBuilder();
	        sb.append('[');
	        if (isEmpty()) {
	            sb.append(']');
	        } else {
	            Node p = head;
	            while (true) {
	                sb.append(p.data);
	                if (p == tail) {
	                    sb.append(']');
	                    break;
	                }
	                sb.append(',');
	                sb.append(' ');
	                p = p.next;
	            }
	        }
	        return sb.toString();
	    }

	    @Override
	    public Iterator<E> iterator() {
	        return new LinkedListIterator();
	    }

	    class LinkedListIterator implements Iterator<E> {
	        private Node cur = head;
	        private boolean flag = true; //是否在第一圈

	        @Override
	        public boolean hasNext() {
	            if (isEmpty()) {
	                return false;
	            }
	            return flag;
	        }

	        @Override
	        public E next() {
	            E ret = cur.data;
	            cur = cur.next;
	            if (cur == head) {
	                flag = false;
	            }
	            return ret;
	        }
	    }

	    //双端队列的方法
	    @Override
	    public void addFirst(E element) {
	        add(0, element);
	    }

	    @Override
	    public void addLast(E element) {
	        add(size, element);
	    }

	    @Override
	    public E removeFirst() {
	        return remove(0);
	    }

	  

	    @Override
	    public E getFirst() {
	        return get(0);
	    }

	    @Override
	    public E getLast() {
	        return get(size - 1);
	    }

	    //栈的方法
	    @Override
	    public void push(E element) {
	        addLast(element);
	    }

	    @Override
	    public E pop() {
	        return removeLast();
	    }

	    @Override
	    public E peek() {
	        return getLast();
	    }

	    //队列的方法
	    @Override
	    public void offer(E element) {
	        addLast(element);
	    }

	    @Override
	    public E poll() {
	        return removeFirst();
	    }

	    @Override
	    public E element() {
	        return getFirst();
	    }
		  
		@Override
		public E removeLast() {
			// TODO Auto-generated method stub
			return remove(size - 1);
		}

}

		

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值