C语言习题 整数排序
时间: 1ms 内存:128M
描述:
用指向指针的指针的方法对n个整数排序并输出。要求将排序单独写成一个函数。整数和n在主函数中输入。最后在主函数中输出。
输入:
n和n个整数
输出:
排序后的整数
示例输入:
5
4 3 2 1 5
示例输出:
1 2 3 4 5
提示:
参考答案(内存最优[748]):
#include <stdio.h>
void sort(int **p,int n)
{
int i,j,*temp;
for (i=0; i<n-1; i++)
{
for (j=i+1; j<n; j++)
{
if (**(p+i)>**(p+j)) //比较后交换整数地址
{
temp=*(p+i);
*(p+i)=*(p+j);
*(p+j)=temp;
}
}
}
}
int main()
{
void sort(int **,int );
int i,n,data[20],**p,*pstr[20];
scanf("%d",&n);
for (i=0; i<n; i++)
pstr[i]=&data[i];
for (i=0; i<n; i++)
scanf("%d",pstr[i]);
p=pstr;
sort(p,n);
for (i=0; i<n; i++)
printf("%d ",*pstr[i]);
return 0;
}
参考答案(时间最优[0]):
#include <stdio.h>
void sort(int **p,int n)
{
int i,j,*temp;
for (i=0; i<n-1; i++)
{
for (j=i+1; j<n; j++)
{
if (**(p+i)>**(p+j)) //比较后交换整数地址
{
temp=*(p+i);
*(p+i)=*(p+j);
*(p+j)=temp;
}
}
}
}
int main()
{
void sort(int **,int );
int i,n,data[20],**p,*pstr[20];
scanf("%d",&n);
for (i=0; i<n; i++)
pstr[i]=&data[i];
for (i=0; i<n; i++)
scanf("%d",pstr[i]);
p=pstr;
sort(p,n);
for (i=0; i<n; i++)
printf("%d ",*pstr[i]);
return 0;
}
题目和答案均来自于互联网,仅供参考,如有问题请联系管理员修改或删除。
