-4

このコードの Big O 表記と Big Omega 表記 (最悪の場合、最良の場合) を知りたいO(n)です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 に答える