【输入形式】首先打印提示&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
把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;
}
}