輸入三個字符串,比較大小,並按順序輸出

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;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章