Я пытаюсь выяснить время выполнения алгоритма сортировки выбором для сортировки уже отсортированного массива (например, 1,2,3,4,5,..) и время его использования для сортировки массива в обратном порядке (например, 5 ,4,3,2..). Странная вещь, которую я обнаружил, заключается в том, что на моем компьютере сортировка уже отсортированного массива занимает больше времени, чем сортировка массива в обратном порядке. Из того, что я узнал, я думаю, что должно быть наоборот.
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void selectionsort(int A[], int n) {
int min;
for (int i = 0; i < n - 1; i++) {
min = i;
for (int k = i + 1; k < n; k++) {
if (A[k] < A[min]) {
min = k;
}
}
int temp = A[i];
A[i] = A[min];
A[min] = temp;
}
}
void sort(int A[], int n) {
for (int i = 0; i < n; i++) {
A[i] = i + 1;
}
}
void resver_sort(int A[], int n) {
for (int i = 0; i < n; i++) {
A[i] = n - i;
}
}
int main() {
clock_t start, end;
double cpu_time_used;
int A[20000] = { 0 };
int B[40000] = {0};
int C[100000] = {0};
printf("Selection Sort, Sorted Array\n");
sort(A, 20000);
start = clock(); // start the clock
selectionsort(A, 20000);
end = clock(); // stop the clock
cpu_time_used = ((double)(end - start)) / CLOCKS_PER_SEC; // calculate the actual time used
printf("array size:20000 time:%f\n", cpu_time_used);
sort(B, 40000);
start = clock();
selectionsort(B, 40000);
end = clock();
cpu_time_used = ((double)(end - start)) / CLOCKS_PER_SEC;
printf("array size:40000 time:%f\n", cpu_time_used);
sort(C, 100000);
start = clock();
selectionsort(C, 100000);
end = clock();
cpu_time_used = ((double)(end - start)) / CLOCKS_PER_SEC;
printf("array size:100000 time:%f\n", cpu_time_used);
printf("Selection Sort, reverse sorted Array\n");
resver_sort(A, 20000);
start = clock();
selectionsort(A, 20000);
end = clock();
cpu_time_used = ((double)(end - start)) / CLOCKS_PER_SEC;
printf("array size:20000 time:%f\n", cpu_time_used);
resver_sort(B, 40000);
start = clock();
selectionsort(B, 40000);
end = clock();
cpu_time_used = ((double)(end - start)) / CLOCKS_PER_SEC;
printf("array size:40000 time:%f\n", cpu_time_used);
resver_sort(C, 100000);
start = clock();
selectionsort(C,100000);
end = clock();
cpu_time_used = ((double)(end - start)) / CLOCKS_PER_SEC;
printf("array size:100000 time:%f\n", cpu_time_used);
}
Результат
Selection Sort, Sorted Array
array size:20000 time:0.530281
array size:40000 time:2.109836
array size:100000 time:13.197117
Selection Sort, reverse sorted Array
array size:20000 time:0.500338
array size:40000 time:2.016468
array size:100000 time:12.830447
Program ended with exit code: 0
Первый, который представляет собой уже отсортированный массив, занимает больше времени. Это не имеет смысла. Я потратил много времени на отладку и попытки распечатать эти массивы, чтобы изучить их, но так и не понял.