c语言编程 写一个函数,实现两个字符串的比较,即写一个类似于strcmp功能的函数。急求,谢谢!

2025-05-11 17:23:43
推荐回答(5个)
回答1:

#include
int strcmp(char *s1, char *s2)
{
while((*s1++ == *s2++)&& *s1);
return (*s1 - *s2);
}
void main()
{
char a[10], b[10];
gets(a);
gets(b);
printf("%d\n", strcmp(a, b));
}

回答2:

#include
#define N 4
int strcomp(char *s1,char *s2)
{ for(;*s1==*s2&&*s1&&*s2;s1++,s2++); /* 找不同的字符 */
return(*s1-*s2); /* 返回字符差值*/
}
void main()
{ char str[N][50];
int i,j;
for(i=0;i { printf("String #%d:",i+1);
gets(str[i]);
}
for(j=0,i=1;i if(strcomp(str[j],str[i])>0) j=i;
printf("Min string is:%s\n",str[j]);
}

回答3:

#include 
int strcompare (char *p1,char *p2);
int main(){
    char p1[100],p2[100];
    int ans;
    gets(p1);
    gets(p2);
    ans = strcompare(p1,p2);
    printf("%d\n",ans);
    return 0;
}
int strcompare (char *p1,char *p2){
    int i;
    for(i=0;p1[i]!='\0' && p2[i]!='\0';i++){
        if(p1[i]==p2[i]) continue;
        else return (p1[i]-p2[i]);
    }
    if(p1[i]=='\0' && p2[i]=='\0') return 0;
    else if(p1[i]=='\0') return -p2[i];
    else return p1[i];
}

回答4:

3137333的程序有问题,应是:
int strcmp(char *s1, char *s2)
{
while((*s1==*s2)&&*s1) {s1++;s2++;}
return(*s1-*s2);
}
原来程序返回的是不相同字符的下一字符的差值!

回答5:

#include 
int strcompare(char *p1, char *p2);
int main()
{
char s1[100];
char s2[100];
gets(s1);
gets(s2);
printf("%d\n", strcompare(s1, s2));
system("pause");
}
int strcompare(char *p1, char *p2)
{
for (; *p1 == *p2&&*p1; p1++, p2++);
return *p1 - *p2;
}