Я должен использовать массивы размером от 10000 до 50000 с размером шага 10000, давать одинаковые входные данные всем трем алгоритмам и для каждого входа повторять выполнение 100 раз, измерять выполнение в наносекундах (используя System.nanoTime()), и сообщить среднее время в миллисекундах. это то, что я сделал ниже, но некоторые средние значения отрицательны, я не знаю, почему?
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... - person Nir Alfasi   schedule 13.10.2017