首页 > 学院 > 开发设计 > 正文

C语言风格字符串

2019-11-14 10:17:11
字体:
来源:转载
供稿:网友

C语言风格字符串


这里写图片描述


字符串的长度:

C语言风格的字符串末尾有一个‘/0’。比如: char * = "HelloWorld"; 在堆内存中会有一个字符数组,它存储的是“HelloWorld”末尾有一个“/0” 在栈内存中会有一个字符指针,名字为str指向字符数组0号位置的字符‘H’ 如下图所示:

这里写图片描述

那么如何求字符串的长度呢?定义一个指针p指向0号位置,然后再定义一个变量初始化为0;把指针p不断往后移动,移动的过程中将那个变量不断加一;最终p所指向的字符是’/0’;这时候停止循环返回定义的变量的值。

求字符串的长度的代码:

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//求字符串的长度int strLength(char* str){ int count=0; //count记录字符串的长度 char* p=str; //定义一个指针指向第一个字符 while(*p++){ //当p没有指向'/0'时,则一直循环往后移动,直到指向'/0' count++; //移动的过程中count增大 } return count;}int main(int argc, char **argv) { char* str=(char*)malloc(sizeof(char)*Max); scanf("%s",str); PRintf("%d %d/n",strLength(str),strlen(str)); //strLength为我们自定义的求长度的方法,strlen为c语言自带的方法 return 0;}

字符串的拷贝:

当考虑目标字符串dest比源字符串src短时:

这里写图片描述

当考虑目标字符串dest比源字符串src长时:

这里写图片描述

求字符串的拷贝的代码:

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//字符串的拷贝void strCopy(char* dest,char* src){ char* p=dest; char* q=src; while(*p++=*q++){ //不断把q所指向的字符向p所指向的字符移动,直到q所指向的字符为'/0' }}int main(int argc, char **argv) { char* dest=(char*)malloc(Max*sizeof(char)); char* src=(char*)malloc(Max*sizeof(char)); gets(dest); gets(src); strCopy(dest,src); //自己编写的字符串拷贝函数 printf("%s/n",dest); free(dest); free(src); dest=(char*)malloc(Max*sizeof(char)); src=(char*)malloc(Max*sizeof(char)); gets(dest); gets(src); strcpy(dest,src); //c语言自带的字符串拷贝函数 printf("%s/n",dest); free(dest); free(src); return 0;}

字符串的连接:

这里写图片描述

首先要保证目标串的尾部,有足够的空间容纳源字符串;步骤:1.求目标字符串的长度2.将源字符串复制到目标串的尾部

字符串的连接的代码:

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//字符串的连接void strCat(char* dest,char* src){ int len=strlen(dest); //求目标字符串的长度 char* p=dest+len; //指针指向目标串的末尾,也就是指向dest字符串的'/0'的位置 strcpy(p,src); //将源串拷贝至目标串末尾}int main(int argc, char **argv) { char* dest=(char*)malloc(Max*sizeof(char)); char* src=(char*)malloc(Max*sizeof(char)); gets(dest); gets(src); strCat(dest,src); //自己编写的字符串的连接 printf("%s/n",dest); free(dest); free(src); dest=(char*)malloc(Max*sizeof(char)); src=(char*)malloc(Max*sizeof(char)); gets(dest); gets(src); strcat(dest,src); //c语言自带字符串的连接 printf("%s/n",dest); free(dest); free(src); return 0;}

字符串的比较:

原则:相等返回0,小于返回-1,大于返回1方法:1.定义两个指针,分别指向两个字符串2.两个指针往后移动,直到指向的连个字符不相等时比较大小3.当都指向了末尾,且之前的都相等,则返回0;4.当长度不相等,且两个指针有一个指向的’/0’,则长度长的大

字符串的比较的代码:

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//比较两个字符串的大小int strCompare(char* s1,char* s2){ char* p=s1; char* q=s2; while(*p==*q&&*p&&*q){ //当指向的字符相等,且都没有指向末尾'/0'时则循环往后移动指针 p++; q++; } if(*p-*q==0){ //当都指向末尾'/0'时,则相等 return 0; }else{ return *p>*q?1:-1; //指向的字符不等时,比较大小;或者有一个指向'/0'也比较大小 }}int main(int argc, char **argv) { char* s1=(char*)malloc(Max*sizeof(char)); char* s2=(char*)malloc(Max*sizeof(char)); gets(s1); gets(s2); printf("%d/n",strCompare(s1,s2)); //自己写的字符串比较函数 free(s1); free(s2); s1=(char*)malloc(Max*sizeof(char)); s2=(char*)malloc(Max*sizeof(char)); gets(s1); gets(s2); printf("%d/n",strcmp(s1,s2)); //系统自带的字符串比较函数 free(s1); free(s2); return 0;}

字符串的大小写转换:

大写转化为小写:指针指向的字符加上32小写转化为大写:指针指向的字符加减32

字符串的大写转化为小写:

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//字符串转小写void strLower(char* s){ char* p=s; while(*p){ if(*p>='A'&&*p<='Z'){ *p+=32; //遇到大写字符,加上32 } p++; }}int main(int argc, char **argv) { char* s=(char*)malloc(Max*sizeof(char)); gets(s); strLower(s); //自己写的大写转化为小写 printf("%s/n",s); free(s); s=(char*)malloc(Max*sizeof(char)); gets(s); strlwr(s); //c语言自带转化为小写 printf("%s/n",s); free(s); return 0;}

字符串的小写转化为大写:

#include <stdio.h>#include <string.h>#include <stdlib.h>const int Max=32;//字符串转大写void strUper(char* s){ char* p=s; while(*p){ if(*p>='a'&&*p<='z'){ *p-=32; //遇到小写字符,减去32 } p++; }}int main(int argc, char **argv) { char* s=(char*)malloc(Max*sizeof(char)); gets(s); strUper(s); //自己写的小写转化为大写 printf("%s/n",s); free(s); s=(char*)malloc(Max*sizeof(char)); gets(s); strupr(s); //c语言自带转化为大写 printf("%s/n",s); free(s); return 0;}
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表