中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

java先進先出數據結構怎么實現

小億
235
2023-12-12 12:52:08
欄目: 編程語言

在Java中,可以使用以下幾種數據結構來實現先進先出(FIFO)的特性:

  1. 隊列(Queue):隊列是先進先出的線性數據結構,可以使用Java中的LinkedList類來實現。LinkedList類提供了常用的隊列操作方法,如add()、offer()、remove()、poll()等。
import java.util.LinkedList;
import java.util.Queue;

public class FIFOQueueExample {
    public static void main(String[] args) {
        Queue<String> queue = new LinkedList<>();

        // 入隊操作
        queue.add("A");
        queue.add("B");
        queue.offer("C");

        // 出隊操作
        String element = queue.remove(); // A
        System.out.println(element);

        String peekElement = queue.peek(); // B
        System.out.println(peekElement);
    }
}
  1. 棧(Stack):盡管棧是一種后進先出(LIFO)的數據結構,但是可以使用LinkedList類的push()和pop()方法模擬先進先出的行為。
import java.util.LinkedList;

public class FIFOStackExample {
    public static void main(String[] args) {
        LinkedList<String> stack = new LinkedList<>();

        // 入棧操作
        stack.push("A");
        stack.push("B");
        stack.push("C");

        // 出棧操作
        String element = stack.pop(); // C
        System.out.println(element);

        String peekElement = stack.peek(); // B
        System.out.println(peekElement);
    }
}
  1. 數組(Array):可以使用數組來實現先進先出的特性。使用一個指針來指示隊列的頭部,每次出隊操作后將指針向后移動一位。
public class FIFODynamicArray {
    private int[] array;
    private int head;
    private int tail;
    private int size;

    public FIFODynamicArray(int capacity) {
        array = new int[capacity];
        head = 0;
        tail = 0;
        size = 0;
    }

    public void enqueue(int element) {
        if (size == array.length) {
            throw new IllegalStateException("Queue is full");
        }
        
        array[tail] = element;
        tail = (tail + 1) % array.length;
        size++;
    }

    public int dequeue() {
        if (size == 0) {
            throw new IllegalStateException("Queue is empty");
        }
        
        int element = array[head];
        head = (head + 1) % array.length;
        size--;

        return element;
    }

    public boolean isEmpty() {
        return size == 0;
    }
}

0
共和县| 香格里拉县| 霍州市| 隆安县| 易门县| 南木林县| 海原县| 临猗县| 拜城县| 墨玉县| 昆明市| 明水县| 彝良县| 石首市| 获嘉县| 华阴市| 内乡县| 祥云县| 平湖市| 汝南县| 延边| 南汇区| 浦县| 舟山市| 濮阳县| 宁远县| 赤城县| 九寨沟县| 呼图壁县| 仁怀市| 鹤岗市| 徐汇区| 安龙县| 屏东县| 阳山县| 图片| 博客| 京山县| 城口县| 营口市| 新乡市|