C言語で配列をソートするコードの書き方を教えてください
以下は配列ソートを行うC言語のコード例です。
#include <stdio.h>
void bubbleSort(int arr[], int n) {
for (int i = 0; i < n-1; i++) {
for (int j = 0; j < n-i-1; j++) {
if (arr[j] > arr[j+1]) {
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
void printArray(int arr[], int n) {
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
}
int main() {
int arr[] = {64, 34, 25, 12, 22, 11, 90};
int n = sizeof(arr)/sizeof(arr[0]);
printf("Original array: \n");
printArray(arr, n);
bubbleSort(arr, n);
printf("Sorted array in ascending order: \n");
printArray(arr, n);
return 0;
}
このコードでは配列をバブルソートアルゴリズムを使ってソートします。最初に、bubbleSort関数という配列と配列長のパラメーターを受け取る整数の配列をソートするために定義します。内部では二つのループを使って順番に隣接する要素を比較し、もし順序が正しくなければ場所を入れ替えて、配列全部に順序がつくまで繰り返します。
配列要素を出力する printArray 関数を定義しました。これは配列要素と配列サイズを引数に受け取ります。
main関数内に整数配列arrを宣言し、sizeof演算子で配列のサイズを計算して初期配列を表示し、bubbleSort関数を呼び出して配列をソートし、ソート後の配列を表示します。