分析
输入:用三个指针分别指向三个字符数组
处理:向sort(cahr**,char**,char**)函数传递指针的地址。用strcmp()来比较两个数组的大小,并两两排序。排序时交换的是原来指针的内容(数组的地址),所以需要指针的指针。
输出:用%s输出三个指针
代码
#include <stdio.h>
#include <string.h>
void sort(char **ppa, char **ppb, char **ppc)
{
char *t=NULL;
if(strcmp(*ppa,*ppb)>0)
{t=*ppa;*ppa=*ppb;*ppb=t;} //*ppa==pa==a,改变*ppa即改变pa的指向
if(strcmp(*ppa,*ppc)>0)
{t=*ppa;*ppa=*ppc;*ppc=t;}
if(strcmp(*ppb,*ppc)>0)
{t=*ppb;*ppb=*ppc;*ppc=t;}
}
int main()
{
char a[10],b[10],c[10];
char *pa=a,*pb=b,*pc=c;
gets(a);
gets(b);
gets(c);
sort(&pa, &pb, &pc);
printf("%s\n%s\n%s", pa, pb, pc);
return 0;
}
结果
版权声明:本文为ACD111原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。