1.总体思路
字符串的比较可以使用
strcmp
函数,返回值
>0
表示大于,返回值小于
0
表示小于,返回追等
于
0
表示相同。其他的比较排序思路与数字的排序交换没有区别,逐个进行比较先找出最大的
具体看一下代码
具体细节已经写进去了,有问题,欢迎指出
#include<stdio.h>
#include<string.h>
void swap ( char **a,char **b)
//需要交换多次,写个函数节省代码,因为要改变pa,pb,pc的内容,
//所以传的是pa,pb,pc的地址,用二级指针,不然临时变量的值无法带回
//函数的形参是临时创建的变量,作用域是局部的,名字可以随便取
{
char *tmp = *a;//跟交换整数一样,注意解应用就行
*a = *b;
*b = tmp;
}
int main ()
{
char str1[30],str2[30],str3[30];//先假设长度不超过30,如果怕不够可以用define定义长度
gets(str1);
gets(str2);
gets(str3);
printf("调整前的字符串:\n%s\n%s\n%s\n",str1,str2,str3);
char * pa = str1, *pb = str2, *pc = str3;//分别指向三个数组,数组本身开辟了一个空间在栈区
//是不能调整指向的,所以通过指针来完成调整
//或者可以选择改变字符数组里的每一个字符,方法
//需要的时候我再重新写
if(strcmp(pa,pb)>0)
{
swap(&pa,&pb);
}
if(strcmp(pa,pc)>0)
{
swap(&pa,&pc);
}
if(strcmp(pb,pc)>0)
{
swap(&pb,&pc);
}
//注意看输出哦;本质上字符串的位置是没有改变的,改变的只有指针指向的对象;
printf("调整后的字符串:\n%s\n%s\n%s\n",pa,pb,pc);
return 0;
}
运行图