字符串练习题(含参考代码)

字符串练习题(含参考代码)

ID:46811288

大小:22.79 KB

页数:7页

时间:2019-11-28

字符串练习题(含参考代码)_第1页
字符串练习题(含参考代码)_第2页
字符串练习题(含参考代码)_第3页
字符串练习题(含参考代码)_第4页
字符串练习题(含参考代码)_第5页
资源描述:

《字符串练习题(含参考代码)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、字符串练习题1.字符串常用函数编程实现。(1)求长度:intmyStrLen(constchar*str)(2)字符串拷贝:char*myStrCpy(char*strSource,constchar*strTarget){char*p1,*p2;for(p1=strSource,p2=strTarget;*p2!=’’;p1++,p2++){*p1=*p2;}*p1=’’;}P1=strSource;p2=strTarget;While(*p1++=*p2++);(3)字符串连接:char*myStrCat(char*strSo

2、urce,constchar*strTarget){char*p1,*p2;//指针要移到字符串strSource的末尾while(*p1!=‘’)p1++;//while(*p1++);p2=strTarget;while(*p2!=’’){*p1=*p2;p1++;p2++;}*p1=’’;//while(*p1++=*p2++);}(1)字符串比较:intmyStrCmp(constchar*str1,constchar*str2)1.判断字符串是否回文。是回文,返回1,不是,则返回0.intisHuiWen(const

3、char*str){intflag=0;//先设为不是,返回0char*pstart,*pend;//指向字符中头、尾的指针pend=str;while(*pend)pend++;//将pend移到字符串末尾pend--;//退回到最后一个有效字符处//开始判断pstart=str;while(*pstart==*pend&&pstart

4、str中查找是否有子串source,若有,将其替换为target子串。替换成功返回1,替换不成功返回0.intstrReplace(char*str,char*source,char*target){//这道题出超界了,改}改3.在字符串str中查找是否有字符source,若有,将其替换为字符target。替换成功返回1,替换不成功返回0.intstrReplace(char*str,charsource,chartarget){intflag=0;//替换是否成功的标识while(*str){if(*str==source)//找到了{

5、*str=target;flag=1;//有过替换,则更新替换成功标识}str++;}returnflag;}1.识别字符串中的整数并转换为数字形式。(华为笔试题)问题描述:识别输入字符串中所有的整数,统计整数个数并将这些字符串形式的整数转换为数字形式整数。要求实现函数:voidtake_num(constchar*str,int*n,unsignedint*outArray)【输入】str:输入的字符串【输出】n:统计识别出来的整数个数outArray:识别出来的整数值,其中outArray[0]是输入字符串中从左到右第一个整数,out

6、Array[1]是第二个整数,依此类推。【返回】无注:(1)、不考虑字符串中出现的正负号(+、-),即所有转换结果为非负整数(包括0和正整数)(2)、不考虑转换后整数超出范围情况,即测试用例中可能出现的最大整数不会超过unsignedint可处理的范围(3)、需要考虑’0’开始的数字字符串情况,比如”00035”,应转换为整数35;”000”应转换为整数0;”00.0035”应转换为整数0和35(忽略小数点:mmm.nnnnnn当成两个整数mmm和nnnnnn来识别)(4)输入字符串假定不会超过100字节。【示例】输入:ab00cd+12

7、3fght456-253.005fgh输出:n=6outArray={0,123,456,25,3,5}voidtake_num(constchar*str,int*n,unsignedint*outArray){intisnum=0;//定义一个是否为数字的标识,0--不是,1--是intnum;//数字字符对应的整数数字*n=0;//整数个数清0while(*str)//字符串未处理完毕{if(*str>='0'&&*str<='9')//是数字字符{num=*str-'0';//转换为数字形式if(isnum)//如果前一个字符是数

8、字字符,则当前字符是某个整数的非第1个数字字符outArray[*n]=outArray[*n]*10+num;else//前一个字符不是数字字符,则当前字符是某个整数的第1个数字字符{out

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。