定义函数void sort(int a[,int n),用选择法对数组a中的元素升序排列。自定义main函数,并在其中调用sort函数

【输入形式】首先打印提示&1dquo:Input n:&rdquo:;然后直接在冒号后面输入正整数n,表示数据的个数;回车;打印提示&1dquo;Input array of n integers:&rdquo:其中应该用如上输入的具体的数值代替;然后直接在冒号后面连续输入n个整数数值,每个数值之间用空格隔开;回车;
【输出形式】打印&1dquo:After50rted the array is:”然后直接在冒号后面输出经升序排序后的数组序列,每个数值之间用空格隔开,第一个数值前面无空格,最后一个数值后面无空格;换行;
【运行时的输入输出样例】(下划线部分表示输入)
Input n:6
Input array 0f 6 ntegers:1 5 -9 2 4 -6
After s0rted the array is:-9 -6 1 2 4 5

img

img

把int a[]修改为 int a[1000];

#include <stdio.h>

void sort(int a[], int n) {
    int i, j, min, temp;
    for (i = 0; i < n-1; i++) {
        min = i;
        for (j = i+1; j < n; j++) {
            if (a[j] < a[min]) {
                min = j;
            }
        }
        temp = a[min];
        a[min] = a[i];
        a[i] = temp;
    }
}

int main(void) {
    int n, i;
    printf("Input n:");
    scanf("%d", &n);
    int a[1000];
    printf("Input array of %d integers:", n);
    for (i = 0; i < n; i++) {
        scanf("%d", &a[i]);
    }
    sort(a, n);
    printf("After Sorted the array is:");
    for (i = 0; i < n; i++) {
        printf("%d", a[i]);
        if (i < n-1) {
            printf(" ");
        }
    }
    printf("\n");
    return 0;
}

#include <stdio.h>
#include <stdlib.h>

void sort(int *a, int n);

int main(void)
{
    int n;
    printf("Input n:");
    scanf("%d", &n);

    int *a = malloc(n * sizeof(int));
    printf("Input array of %d integers:", n);
    for (int i = 0; i < n; i++) scanf("%d", &a[i]);

    sort(a, n);

    printf("After sorted the array is:");
    for (int i = 0; i < n; i++)
    {
        printf("%d", a[i]);
        if (i < n - 1) printf(" ");
    }
    printf("\n");
}

void sort(int *a, int n)
{
    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;
        }
        int temp = a[i];
        a[i] = a[min];
        a[min] = temp;
    }
}