c 语言 str_scomp,C语言及程序设计提高例程-31 编制自己的字符串函数

贺老师教学链接  C语言及程序设计提高 本课讲解

字符串复制

#include

char *scopy(char *str1, const char *str2);

int main()

{

char s1[50];

scopy(s1, "I am happy.");

printf("%s\n", s1);

return 0;

}

char *scopy(char *str1, const char *str2)

{

int i=0,j=0;

while(str2[j]!='\0')

{

str1[i]=str2[j];

i++;

j++;

}

str1[i]='\0';

return str1;

}

另解:字符串复制

#include

char *scopy(char *str1, const char *str2);

int main()

{

char s1[50];

scopy(s1, "I am happy.");

printf("%s\n", s1);

return 0;

}

char *scopy(char *str1, const char *str2)

{

char *p1=str1;

const char *p2=str2;

while(*p2!='\0')

{

*p1=*p2;

p1++;

p2++;

}

*p1='\0';

return p1;

}

比较字符串(忽略大小写)

#include

#include

int scomp(const char *str1, const char *str2);

int main()

{

printf("%d\n", scomp("PFXa", "pfXA"));

printf("%d\n", scomp("PF12", "pF34"));

printf("%d\n", scomp("Bxb3", "bdeF"));

return 0;

}

int scomp(const char *str1, const char *str2)

{

const char *p=str1,*q=str2;

while(tolower(*p)==tolower(*q)&&*p!='\0'&&*q!='\0')

{

p++;

q++;

}

if (tolower(*p)>tolower(*q))

return 1;

else if(tolower(*p)

return -1;

else

return 0;

}

另解:比较字符串(忽略大小写)

#include

int scomp(const char *str1, const char *str2);

int main()

{

printf("%d\n", scomp("PFXa", "pfXA"));

printf("%d\n", scomp("PF12", "pF34"));

printf("%d\n", scomp("Bxb3", "bdeF"));

return 0;

}

int scomp(const char *str1, const char *str2)

{

int i=0, j=0;

char c1, c2;

do

{

c1=(str1[i]>='A'&&str1[i]<='Z')?str1[i]+32:str1[i];

c2=(str2[i]>='A'&&str2[i]<='Z')?str2[i]+32:str2[i];

i++;

j++;

}while(c1==c2&&c1!='\0'&&c2!='\0');

if (c1>c2)

return 1;

else if(c1

return -1;

else

return 0;

}

统计单词个数

#include

int wordnum(const char *str);

int main()

{

char s[81];

gets(s);

printf("\"%s\" have %d words.\n", s, wordnum(s));

return 0;

}

/*

关键:word代表一种状态

word==0时,之前读到了空格

- 现读到空格,word保持0

- 现读到了非空格,单词数增1,word置为1

word==1时,之前读到的是非空格

- 现读到空格,word重置为0

- 现读到了非空格,继续读

*/

int wordnum(const char *str)

{

int i,num=0,word=0; //word为0,代表现在并不

for(i=0; (*(str+i)!='\0'); i++)

{

if (*(str+i)==' ')

word=0;

else if (word==0)

{

word=1;

num++;

}

}

return num;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值