0
?時間の複雑さを計算するにはどうすればいいのですか。時間複雑ソート
#include <stdio.h>
void shellsort(int arr[], int num)
{
int i, j, k, tmp;
for (i = num/2; i > 0; i = i/2)
{
for (j = i; j < num; j++)
{
for (k = j - i; k >= 0; k = k - i)
{
if (arr[k + i] >= arr[k])
break;
else
{
tmp = arr[k];
arr[k] = arr[k + i];
arr[k + i] = tmp;
}
}
}
}
}
int main()
{
int arr[30];
int k, num;
printf("Enter total no. of elements : ");
scanf("%d", &num);
printf("\nEnter %d numbers: ", num);
for (k = 0; k < num; k++)
{
scanf("%d", &arr[k]);
}
shellsort(arr, num);
printf("\n Sorted array is: ");
for (k = 0; k < num; k++)
printf("%d ", arr[k]);
return 0;
}
(データ構造とアルゴリズム分析をマークアレンワイスまたはいくつかの他の)://en.mシェルの.wikipedia.org /ウィキ/ Time_complexity –
漸近的複雑さは、ソートその答え(https://en.wikipedia.org/wiki/Shellsortを参照)実装の詳細に依存するトリッキーな質問です。これは、SOが受け入れるよりはるかに広い問題です。 –
コードフォーマット、スペル/文法 – Constantin