数据结构(Java)-持续更新补充

简介: 复习一下数据结构,巩固一下基础。 之后打算再学一下算法,之前刷题总感觉摸不清门道,应该是概念没彻底搞明白。

复习一下数据结构,巩固一下基础。
之后打算再学一下算法,之前刷题总感觉摸不清门道,应该是概念没彻底搞明白。

import java.util.Arrays;

public class Stack {
    private int size;
    private int[] array;
    
    public Stack() {
        this(10);
    }
    public Stack(int init) {
        if(init <= 0) {
            init = 10;
        }
        array = new int[init];
    }
    public void push(int item) {
        if(size == array.length) {
            array = Arrays.copyOf(array, size * 2);
        }
        array[size++] = item;
    }
    public int peek() {
        if(size == 0) {
            throw new ArrayIndexOutOfBoundsException("栈已经空啦");
        }
        return array[size - 1];
    }
    public int pop() {
        int item = peek();
        size--;
        return item;
    }
    public boolean isFull() {
        return size == array.length;
    }
    public boolean isEmpty() {
        return size == 0;
    }
    public int size() {
        return size;
    }
}

队列


public class ArrayQueue {
    private final Object[] items;
    private int head;
    private int tail;
    public ArrayQueue(int capacity) {
        this.items = new Object[capacity];
    }
    public boolean put(Object item) {
        if(head == (tail + 1) % items.length) {
            return false;
        }
        items[tail] = item;
        tail = (tail + 1) % items.length;
        return true;
    }
    public Object peek() {
        if(head == tail) {
            return null;
        }
        return items[head];
    }
    public Object poll() {
        if(head == tail) {
            return null;
        }
        Object item = items[head];
        items[head] = null;
        head = (head + 1) % items.length;
        return item;
    }
    public boolean isFull() {
        return head == (tail + 1) % items.length;
    }
    public boolean isEmpty() {
        return head == tail;
    }
    public int size() {
        if(head <= tail) {
            return tail - head;
        }
        return tail - head + items.length;
    }
}

用栈来模拟队列


public class Stack2Queue {
    private Stack stack1;
    private Stack stack2;
    private int maxLength;
    public Stack2Queue(int capacity) {
        maxLength = capacity;
        stack1 = new Stack(capacity);
        stack2 = new Stack(capacity);
    }
    public boolean put(int item) {
        if(stack1.isFull() || size() == maxLength) {
            return false;
        }
        stack1.push(item);
        return true;
    }
    public int poll() {
        if(!stack2.isEmpty()) {
            return stack2.pop();
        }else {
            while(!stack1.isEmpty()) {
                stack2.push(stack1.pop());
            }
            return stack2.pop();
        }
    }
    public int size() {
        return stack1.size() + stack2.size();
    }
}

用队列来模拟栈


public class Queue2Stack {
    private ArrayQueue queue1;
    private ArrayQueue queue2;
    private int maxLength;
    public Queue2Stack(int capacity) {
        maxLength = capacity;
        queue1 = new ArrayQueue(capacity);
        queue2 = new ArrayQueue(capacity);
    }
    public boolean push(Object item) {
        if(size() == maxLength) {
            return false;
        }
        if(queue2.isEmpty()) {
            queue1.put(item);
        }else {
            queue2.put(item);
        }
        return true;
    }
    public Object pop() {
        if(size() == 0) {
//            return null;
            throw new IndexOutOfBoundsException("栈里空啦");
        }
        if(queue2.isEmpty()) {
            while(queue1.size() > 1) {
                queue2.put(queue1.poll());
            }
            return queue1.poll();
        }else {
            while(queue2.size() > 1) {
                queue1.put(queue2.poll());
            }
            return queue2.poll();
        }
    }
    public int size() {
        return queue1.size() + queue2.size();
    }
}

链表

public class Node {
    private int data;
    private Node next;
    public int getData() {
        return data;
    }
    public void setData(int data) {
        this.data = data;
    }
    public Node getNext() {
        return next;
    }
    public void setNext(Node next) {
        this.next = next;
    }
}

public class Link {
    private int size = 0;
    private Node first;
    private Node last;
    
    public Link() {
        
    }
    public void addFirst(int data) {
        if(size == 0) {
            fillStart(data);
        }else {
            Node node = new Node();
            node.setData(data);
            node.setNext(first);
            first = node;
            size++;
        }
    }
    public void addLast(int data) {
        if(size == 0) {
            fillStart(data);
        }else {
            Node node = new Node();
            node.setData(data);
            last.setNext(node);
            last = node;
            size++;
        }
    }
    public void add(int data, int index) {
        if(size > index) {
            if(size == 0) {
                fillStart(data);
            }else if(index == 0) {
                addFirst(data);
            }else if (index == size -1) {
                addLast(data);
            }else {
                Node node = new Node();
                node = get(index - 1);
                Node temp = new Node();
                temp.setData(data);
                temp.setNext(node.getNext());
                node.setNext(temp);
                size++;
            }
        }else {
            throw new IndexOutOfBoundsException("链表没有这么长");
        }
    }
    public void removeFirst() {
        if(size == 0) {
            throw new IndexOutOfBoundsException("链表中没有元素");
        }else if(size == 1) {
            clear();
        }else {
            Node node = first;
            first = first.getNext();
            node = null;
            size--;
        }
    }
    public void removeLast() {
        if(size == 0) {
            throw new IndexOutOfBoundsException("链表中没有元素");
        }else if(size == 1) {
            clear();
        }else {
            Node node = get(size -2);
            node.setNext(null);
            last = node;
            size--;
        }
    }
    public void removeMiddle(int index) {
        if(size == 0) {
            throw new IndexOutOfBoundsException("链表中没有元素");
        }else if(size == 1) {
            clear();
        }else {
            Node node = get(index - 1);
            Node temp = node.getNext();
            node.setNext(temp.getNext());
            size--;
        }
    }
    public int size() {
        return size;
    }
    public void clear() {
        first = null;
        last = null;
        size = 0;
    }
    public Node get(int index) {
        Node temp = first;
        for(int i = 0; i < index; i++) {
            temp = temp.getNext();
        }
        return temp;
    }
    private void fillStart(int data) {
        first = new Node();
        first.setData(data);
        last = first;
        size++;
    }
    public void printAll() {
        Node temp = first;
        System.out.println(temp.getData());
        for(int i = 0; i < size - 1; i++) {
            temp = temp.getNext();
            System.out.println(temp.getData());
        }
    }
}

暂时先复习了这么多,本文持续更新~
如果有啥觉得可以补充或者建议,可以留言噢~

参考:

  1. 《轻松学算法》赵烨
目录
相关文章
|
3月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
101 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
3月前
|
存储 Java
Java中的HashMap和TreeMap,通过具体示例展示了它们在处理复杂数据结构问题时的应用。
【10月更文挑战第19天】本文详细介绍了Java中的HashMap和TreeMap,通过具体示例展示了它们在处理复杂数据结构问题时的应用。HashMap以其高效的插入、查找和删除操作著称,而TreeMap则擅长于保持元素的自然排序或自定义排序,两者各具优势,适用于不同的开发场景。
56 1
|
3月前
|
存储 Java
告别混乱!用Java Map优雅管理你的数据结构
【10月更文挑战第17天】在软件开发中,随着项目复杂度增加,数据结构的组织和管理至关重要。Java中的Map接口提供了一种优雅的解决方案,帮助我们高效、清晰地管理数据。本文通过在线购物平台的案例,展示了Map在商品管理、用户管理和订单管理中的具体应用,有效提升了代码质量和维护性。
98 2
|
3月前
|
存储 Java 开发者
Java Map实战:用HashMap和TreeMap轻松解决复杂数据结构问题!
【10月更文挑战第17天】本文深入探讨了Java中HashMap和TreeMap两种Map类型的特性和应用场景。HashMap基于哈希表实现,支持高效的数据操作且允许键值为null;TreeMap基于红黑树实现,支持自然排序或自定义排序,确保元素有序。文章通过具体示例展示了两者的实战应用,帮助开发者根据实际需求选择合适的数据结构,提高开发效率。
88 2
|
23天前
|
存储 缓存 安全
Java 集合江湖:底层数据结构的大揭秘!
小米是一位热爱技术分享的程序员,本文详细解析了Java面试中常见的List、Set、Map的区别。不仅介绍了它们的基本特性和实现类,还深入探讨了各自的使用场景和面试技巧,帮助读者更好地理解和应对相关问题。
40 5
|
2月前
|
缓存 算法 Java
本文聚焦于Java内存管理与调优,介绍Java内存模型、内存泄漏检测与预防、高效字符串拼接、数据结构优化及垃圾回收机制
在现代软件开发中,性能优化至关重要。本文聚焦于Java内存管理与调优,介绍Java内存模型、内存泄漏检测与预防、高效字符串拼接、数据结构优化及垃圾回收机制。通过调整垃圾回收器参数、优化堆大小与布局、使用对象池和缓存技术,开发者可显著提升应用性能和稳定性。
54 6
|
2月前
|
存储 Java 索引
Java中的数据结构:ArrayList和LinkedList的比较
【10月更文挑战第28天】在Java编程世界中,数据结构是构建复杂程序的基石。本文将深入探讨两种常用的数据结构:ArrayList和LinkedList,通过直观的比喻和实例分析,揭示它们各自的优势与局限,帮助你在面对不同的编程挑战时做出明智的选择。
|
3月前
|
存储 算法 Java
Java 中常用的数据结构
【10月更文挑战第20天】这些数据结构在 Java 编程中都有着广泛的应用,掌握它们的特点和用法对于提高编程能力和解决实际问题非常重要。
37 6
|
3月前
|
存储 Java 开发者
Java中的Map接口提供了一种优雅的方式来管理数据结构,使代码更加清晰、高效
【10月更文挑战第19天】在软件开发中,随着项目复杂度的增加,数据结构的组织和管理变得至关重要。Java中的Map接口提供了一种优雅的方式来管理数据结构,使代码更加清晰、高效。本文通过在线购物平台的案例,展示了Map在商品管理、用户管理和订单管理中的具体应用,帮助开发者告别混乱,提升代码质量。
37 1
|
3月前
|
存储 算法 Java
Java常用的数据结构
【10月更文挑战第3天】 在 Java 中,常用的数据结构包括数组、链表、栈、队列、树、图、哈希表和集合。每种数据结构都有其特点和适用场景,如数组适用于快速访问,链表适合频繁插入和删除,栈用于实现后进先出,队列用于先进先出,树和图用于复杂关系的表示和查找,哈希表提供高效的查找性能,集合用于存储不重复的元素。合理选择和组合使用这些数据结构,可以显著提升程序的性能和效率。