比较大小:
(1)指针版本:
#include <stdio.h>
#include <string.h>
int mycmp(const char* s1,const char* s2)
{
while( *s1 == *s2 && *s1 != '\0'){
s1 ++;
s2 ++;
}
return *s1 - *s2;
}
int main(int argc,char const *argv[])
{
char s1[] = "abc";
char s2[] = "Abc";
printf("%d\n",mycmp(s1,s2));
printf("%d\n",'a'-'A');
return 0;
}
重点是函数mycmp那里的判断条件,这个程序是为了判断两个字符串的大小,循环继续的条件是s1==s2并且第一个字符串并没有到头,如果不满足第一个条件说明两个字符串已经出现了不一样的字符;如果不满足第二个条件说明字符串以及遍历完成,两个数组一模一样。
(2)数组版本
#include <stdio.h>
#include <string.h>
int mycmp(const char* s1,const char* s2)
{
int idx;
while(s1[idx] == s2[idx] && s1[idx] != '\0'){
idx ++;
}
return s1[idx] - s2[idx];
}
int main(int argc,char const *argv[])
{
char s1[] = "abc";
char s2[] = "Abc";
printf("%d\n",mycmp(s1,s2));
printf("%d\n",'a'-'A');
return 0;
}
字符串复制函数
(1)指针版本
#include <stdio.h>
#include <string.h>
char* mycpy(char* dst,const char* src)
{
char* ret = dst;
while(*dst == *src++)
;
*dst = '\0';
return ret;
}
int main(int argc,char const *argv[])
{
char s1[] = "abc";
char s2[] = "abc";
strcpy(s1,s2);
return 0;
}
(2)数组版本
#include <stdio.h>
#include <string.h>
char* mycpy(char* dst,const char* src)
{
int idx = 0;
while(src[idx]){
dst[idx] = src[idx];
idx ++;
}
dst[idx] = '\0';
return dst;
}
int main(int argc,char const *argv[])
{
char s1[] = "abc";
char s2[] = "abc";
strcpy(s1,s2);
return 0;
}