1、不用庫函數
#include <stdio.h>
#include <string.h>
#define N 10
int compare(char s1[],char s2[],int n);
int main(){
char s[3][N],min;
int i,j,k,t,count[3]={0,1,2};
for(i=0;i<3;i++){
printf("請輸入第%d個字符串\n",i+1);
scanf("%s",s[i]);
}
for(j=0;j<2;j++)
for(i=j+1;i<3;i++){
k = compare(s[count[j]],s[count[i]],i);
if(!k){
t=count[j];
count[j]=count[i];
count[i]=t;
}
}
for(i=0;i<3;i++){
printf("%s\n",s[count[i]]);
}
return 0;
}
/*
比較兩個字符串的大小,s1>=s2,返回1,否則返回0
*/
int compare(char s1[],char s2[],int n){
int i=0,count;
while(s1[i]!='\0'&&s2[i]!='\0'){
if(s1[i]>s2[i]){
count=1;
break;
}else if(s1[i]<s2[i]){
count=0;
break;
}else i++;
}
if(s1[i]=='\0'){
count=0;
}else if(s2[i]=='\0'){
count=1;
}
return count;
}
2、使用庫函數
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define N 10
int main(){
char *p[3],line[N];
char *q;
int i,j;
for(i=0;i<3;i++){
printf("請輸入第%d個字符串\n",i+1);
scanf("%s",line);
p[i]=(char *)calloc(strlen(line),1);
strcpy(p[i],line);
}
for(i=2;i>0;i--){
for(j=i;j>0;j--){
if(strcmp(p[j],p[j-1])==-1){
q=p[j];
p[j]=p[j-1];
p[j-1]=q;
}
}
}
for(i=2;i>=0;i--){
printf("%s\n",p[i]);
}
return 0;
}