Enqueue values at the back and dequeue them from the front in first-in, first-out order.

Algorithm

The replay uses the same three values in every language, so this Java DSA implementation can be compared directly with the rest of the DSA track.

Basic Implementation

Basic.java
import java.util.*;

public class Basic {
    static String render(List<Integer> values) {
        StringBuilder out = new StringBuilder();
        for (int i = 0; i < values.size(); i++) {
            if (i > 0) out.append(" -> ");
            out.append(values.get(i));
        }
        return out.toString();
    }
    public static void main(String[] args) {
        Queue<Integer> queue = new ArrayDeque<>();
        for (int value : new int[] {10, 20, 30}) queue.add(value);
        List<Integer> removed = new ArrayList<>();
        while (!queue.isEmpty()) removed.add(queue.remove());
        System.out.println(render(removed));
    }
}

Complexity

  • Time: O(1) per operation with a real queue
  • Space: O(n)

Implementation notes

  • Keep the explicit stack/queue operations. Library shortcuts that only produce the final list hide the data-structure behavior this lesson is meant to replay.
  • The final output uses a deterministic a -> b -> c format for cross-language comparison.
front The front is the oldest value still waiting in the queue.
FIFO A queue removes values in first-in, first-out order.