排序单独写成一个函数,n个整数在main()中输入和输出。
代码:
#include <stdio.h>
#include <string.h>
int main()
{
void sort(int **, int);
int num[50], *p1[50], i, n, **p2;
for (i = 0; i < 50; i++)
{
p1[i] = num + i;
}
printf("input numbers:\n");
scanf_s("%d", &n);
printf("input them:\n");
for (i = 0; i < n; i++)
scanf_s("%d", p1[i]);
p2 = p1;
sort(p2,n);
printf("numbers sorted:\n");
for (i = 0; i < n; i++)
printf("%d\n", *p1[i]);
return 0;
}
void sort(int **p,int n)
{
int *t, i, j;
for(i=0;i<n-1;i++)
for (j = i + 1; j < n; j++)
{
if (**(p + i) > **(p + j))
{
t = *(p + i);
*(p + i) = *(p + j);
*(p + j) = t;
}
}
}
思考一下将第20行 printf("%d\n", *p1[i]); 改成 printf("%d\n", num[i]); 会发生什么