-4

我想知道这段代码的大 O 表示法和大欧米茄表示法(最坏情况,最好情况) 这是一个排序算法,我猜它有一个O(n)and Omega(n)

public static void swap(int[] A, int i,int j){
    int temp = 0;
    temp = A[i];
    A[i] = A[j];
    A[j] = temp;
}

public static int[] MyAlgorithm(int[] A, int n){

    boolean done = true;
    int j =0;
    while(j<=(n-2)){
        if(A[j]>A[j+1]){
            swap(A,j,j+1);
            done = false;
        }
        j = j+1;
    }
    j = n-1;

    while(j>=1){
        if(A[j]<A[j-1]){
            swap(A, j-1,j);
            done = false;
        }
        j = j-1;
    }

    if(done==false){
        MyAlgorithm(A,n);
    }

    return A;
}
4

1 回答 1

2

它是 O(n^2) (对于 list [n, n-1, ..., 1]), Omega(n) 对于[1, 2, ..., n].

于 2013-05-21T14:18:53.303 回答