基于C++实现去除字符串头尾指定字符功能_第1页
基于C++实现去除字符串头尾指定字符功能_第2页
基于C++实现去除字符串头尾指定字符功能_第3页
基于C++实现去除字符串头尾指定字符功能_第4页
基于C++实现去除字符串头尾指定字符功能_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第基于C++实现去除字符串头尾指定字符功能目录一、从头部开始去除指定字符二、去除尾部指定的字符三、测试比较编程时我们经常需要对字符串进行操作,其中有一项操作就是去除字符串的头(尾)指定的字符,比如空格。通常我们会使用封装好的库函数或者类函数的Trim方法来实现,如果自己动手写一个TrimHead和TrimTail函数该如何实现呢?

本文针对字符串头(尾)部指定的字符的去除,分别给出两个实现方法。并分别比较一下改进后的性能如何?

一、从头部开始去除指定字符

首先从头遍历,直到遇见第一个非指定字符,此后将后续字符按顺序逐一前移。

//实现方式一

voidTrimHead(char*pszSrc,charchTrim)

if(NULL==pszSrc)

return;

//从头部开始跳过chTrim指定的字符

inti=0;

char*psz=pszSrc;

while(*psz*psz==chTrim){

i++;

psz++;

//从psz开始将后面字符逐一拷贝到前面

i=0;

while(*psz)

*(pszSrc+i)=*psz;

i++;

psz++;

*(pszSrc+i)=0;

上述函数中,在找到第一个非指定字符后,通过while函数逐一前移字符,如果后续字符串很长的话,性能是不是会比较低?我们改进一下,使用memmove函数替换while操作,下面是实现方法,代码更加简洁易读。

//实现方式二

voidTrimHeadEx(char*pszSrc,charchTrim)

if(NULL==pszSrc)

return;

//从头部开始跳过chTrim指定的字符

intiStrLen=strlen(pszSrc);

char*psz=pszSrc;

while(*psz*psz==chTrim)

psz++;

//psz指向第一个非指定字符的位置

if(psz!=pszSrc)

//计算新字符串长度

iStrLen=iStrLen-(psz-pszSrc);

memmove(pszSrc,psz,(iStrLen+1));//+1表示将末尾的0也一并拷贝

方法二的代码要比方法一的简洁,那么它的速度会比方法一的快么?文末会给出答案。

二、去除尾部指定的字符

//实现方式一

voidTrimTail(char*pszSrc,charchTrim)

if(NULL==pszSrc)

return;

char*psz=pszSrc;

char*pszLast=NULL;

//从头开始遍历直到整个字符串结束

while(*psz)

//遇到指定字符,则用pszLast记住该位置

if(*psz==chTrim)

if(NULL==pszLast)

pszLast=psz;

else

pszLast=NULL;

psz++;

//如果找到末尾的第一个指定字符,则作为字符串的结尾

if(pszLast!=NULL)

*pszLast=0;

上述方法中,我们需要遍历完整个字符串,如果字符串很长的话,或者遇到极端情况,就是结尾没有指定字符时,也要将整个字符串遍历完毕。显然这种实现方式的效率并不高。那么我们改进一下算法,从字符串的尾部进行遍历。

//实现方式二

voidTrimTailEx(char*pszSrc,charchTrim)

if(NULL==pszSrc)

return;

//从尾部开始跳过chTrim指定字符

intiStrLen=strlen(pszSrc);

char*pszStr=pszSrc;

intiLastIdx=iStrLen-1;

while(iLastIdx=0*(pszStr+iLastIdx)==chTrim)

iLastIdx--;

//计算新字符串长度并在结尾赋值为0

iStrLen=iLastIdx+1;

*(pszSrc+iStrLen)=0;

上述实现方式是从字符串的尾部进行遍历,实现的方式也更加的简洁。如果结尾没有指定字符,该函数会在遍历第一个字符后就退出,性能显然要好过方式一。

那么对于TrimHead和TrimTail的两种实现,方式二和方式一到底谁快呢?是不是和我们想象的一样有差距或者差距很大呢?

三、测试比较

这里写了一个测试函数TestSpeedTrim,为了让时间更加明显,在该函数中设置的循环次数为10000000。大家可以亲自运行测试一下,看看debug和release两个版本的差异,结果一定会让你吃惊,可能和你想的并不一样哦。

#includetime.h

#includestdio.h

#includestring.h

#includestdlib.h

voidTestSpeedTrim(boolbTrimHead)

charszTrim1[256]={0};

charszTrim2[256]={0};

char*pszOrigin="Thisisatrimtesthead/tail";

strcpy(szTrim1,pszOrigin);

strcpy(szTrim2,pszOrigin);

inti=0;

intiCount=10000000;

clock_tcStart=0;

//第一种Trim方法

cStart=clock();

for(i=0;iiCount;i++)

bTrimHeadTrimHead(szTrim1,''):TrimTail(szTrim1,'');

clock_tcSpan1=clock()-cStart;

//第二种Trim方法

cStart=clock();

for(i=0;iiCount;i++)

bTrimHeadTrimHeadEx(szTrim2,''):TrimTailEx(szTrim2,'');

clock_tcSpan2=clock()-cStart;

printf("cSpan1=%d,cSpan2=%d\r\n",cSpan1,cSpan2);

printf("szTrim1=[%s]\r\n",szTrim1);

printf("szTrim2=[%s]\r\n",szTrim2);

intmain(intargc,char*argv[])

//测试头

printf("删除头部的空字符:\r\n");

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论