我必須使用大小範圍從10000到50000,步長爲10000的數組,給所有三種算法提供相同的輸入,並且對於每個輸入重複執行100次,以納秒爲單位測量執行 (使用System.nanoTime( )),並以毫秒爲單位報告平均時間。 這就是我在下面做的,但一些平均值是負值我不知道爲什麼?爲什麼3種算法的平均時間爲負值?
import java.util.Arrays;
public class Sort{
public static void main(String[]args){
double[] arr5 = new double[50000];
for(int i=0;i<arr5.length;i++)
arr5[i] = Math.random();
selectionSort(arr5,10000);
bubbleSort(arr5,10000);
quickSort(arr5,10000);
selectionSort(arr5,20000);
bubbleSort(arr5,20000);
quickSort(arr5,20000);
selectionSort(arr5,30000);
bubbleSort(arr5,30000);
quickSort(arr5,30000);
selectionSort(arr5,40000);
bubbleSort(arr5,40000);
quickSort(arr5,40000);
selectionSort(arr5,50000);
bubbleSort(arr5,50000);
quickSort(arr5,50000);
}
public static void selectionSort(double [] A,int n){
int sum = 0;
System.out.println("Algorithm 1");
for(int s=0;s<100;s++){
long arr[] = new long[100];
long startTime = System.nanoTime();
for(int i=0;i<n-1;i++){
int min = i;
for(int j=i+1;j<n;j++){
if(A[j] < A[min])
min=j;}
double tmp = A[i];
A[i] = A[min];
A[min]=tmp;}
long endTime = System.nanoTime();
arr[s] = endTime - startTime;
//System.out.println(arr[s]);
sum+=arr[s];
}
System.out.println("Average:" + ((sum/100)*Math.pow(10,-6)));
}
public static void bubbleSort(double A [],int n){
int sum = 0;
System.out.println("\nAlgorithm 2");
for(int s=0;s<100;s++){
long[] arr = new long[100];
long startTime = System.nanoTime();
for(int i=0;i<n-1;i++){
for(int j=0;j<n-1-i;j++){
if(A[j]<A[j+1]){
double tmp = A[j];
A[j] = A[j+1];
A[j+1] = tmp;}}}
long endTime = System.nanoTime();
arr[s] = endTime - startTime;
//System.out.println(arr[s]);
sum+=arr[s];
}
System.out.println("Average:" + ((sum/100)*Math.pow(10,-6)));
}
//algorithm 3
public static void quickSort(double A [],int n){
int sum = 0;
System.out.println("\nAlgorithm 3");
long[] arr = new long[100];
for(int i=0;i<100;i++){
long startTime = System.nanoTime();
Arrays.sort(A,0,n-1);
long endTime = System.nanoTime();
arr[i] = endTime - startTime;
//System.out.println(arr[i]);
sum+=arr[i];
}
System.out.println("Average:" + ((sum/100)*Math.pow(10,-6)));
}
}
另一個問題是你正在創建數組:'long arr [] = new long [100];'在for循環裏面... – alfasin