算法描述:编写一个函数,实现两个字符串的比较,即自己写一个strcmp函数,函数原型为
int strcmp(char *p1, char *p2);
设p1指向字符串s1,p2指向字符串s2。要求当s1= s2时,返回值为0;若s1 != s2,返回他们二者第一个不同字符的ASCII码差值(如“BOY”与“BAD”,第二个字母不同,“O”与“A”之差为79 - 65 = 14)。如果s1 > s2,则输出正值;如果s1 < s2,则输出负值。
#include <stdio.h>
int strcmp(char *p1, char *p2)
{
int i = 0;
while(*(p1 + i) == *(p2 + i))
if (*(p1 + i++) == '\0')//++的优先级大于+
return 0;
return *(p1 + i) - *(p2 + i);
}
int main()
{
int m;
char str1[20], str2[20], *p1, *p2;
printf("input two strings:\n");
scanf("%s",str1);//scanf()在输入数据时,遇空格或按enter或tab键,结束该数据输入
scanf("%s",str2);
p1 = str1;
p2 = str2;
m = strcmp(p1, p2);
printf("result:%d\n",m);
return 0;
}