C言語で配列の大きさをソートするためにポインタを使用する方法は何ですか?

配列のサイズをソートする方法には、ポインタを使用することができます。

  1. 元素のアドレスを格納するためのポインタ配列を定義します。
  2. ポインタ配列の要素を比較するために2重ループを使用し、最小の要素のアドレスを見つけ、それを現在のループの要素と交換します。
  3. ループが終了すると、ポインタ配列の要素は小さい順に並べられます。
  4. 指針配列にアクセスすることで、元の配列の要素にアクセスし、配列のサイズの並べ替えを実現できます。

ポインタを使用して配列をサイズでソートする例です。

#include <stdio.h>

void sortArray(int *arr, int size) {
    int *ptrArr[size]; // 指针数组,存储原始数组每个元素的地址
    
    // 初始化指针数组
    for (int i = 0; i < size; i++) {
        ptrArr[i] = &arr[i];
    }
    
    // 使用选择排序法对指针数组进行排序
    for (int i = 0; i < size - 1; i++) {
        int minIndex = i;
        
        for (int j = i + 1; j < size; j++) {
            if (*ptrArr[j] < *ptrArr[minIndex]) {
                minIndex = j;
            }
        }
        
        // 交换指针数组中的元素
        int *temp = ptrArr[i];
        ptrArr[i] = ptrArr[minIndex];
        ptrArr[minIndex] = temp;
    }
    
    // 输出排序后的结果
    printf("排序后的数组:");
    for (int i = 0; i < size; i++) {
        printf("%d ", *ptrArr[i]);
    }
    printf("\n");
}

int main() {
    int arr[] = {5, 3, 2, 4, 1};
    int size = sizeof(arr) / sizeof(arr[0]);
    
    sortArray(arr, size);
    
    return 0;
}

実行結果:

排序后的数组:1 2 3 4 5
bannerAds