队列 03 队列的时间复杂度比较

ArrayQueue 时间复杂度的瓶颈

  • 由于 ArrayQueue 的 dequeue 操作的时间复杂度为 O(n),即数组删除第一个元素,也就是说每次出队都要移动所有元素;
import java.util.Random;

public class Main {

    // 测试使用q运行opCount个enqueueu和dequeue操作所需要的时间,单位:秒
    private static double testQueue(Queue q, int opCount){
        long startTime = System.nanoTime();

        Random random = new Random();
        for(int i = 0 ; i < opCount ; i ++)
            q.enqueue(random.nextInt(Integer.MAX_VALUE));
        for(int i = 0 ; i < opCount ; i ++)
            q.dequeue();

        long endTime = System.nanoTime();
        return (endTime - startTime) / 1000000000.0;
    }

    public static void main(String[] args) {
        int opCount = 100000;

        ArrayQueue arrayQueue = new ArrayQueue<>();
        double time1 = testQueue(arrayQueue, opCount);
        System.out.println("ArrayQueue, time: " + time1 + " s");

        LoopQueue loopQueue = new LoopQueue<>();
        double time2 = testQueue(loopQueue, opCount);
        System.out.println("LoopQueue, time: " + time2 + " s");
    }

}
输出

ArrayQueue, time: 4.7585816 s
LoopQueue, time: 0.017241299 s

结论

O(n) 的操作和 O(1) 的操作差别极大;

你可能感兴趣的:(队列 03 队列的时间复杂度比较)