重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
一些常见的字符串处理函数实现
七里河网站建设公司成都创新互联公司,七里河网站设计制作,有大型网站制作公司丰富经验。已为七里河上1000家提供企业网站建设服务。企业网站搭建\成都外贸网站建设公司要多少钱,请找那个售后服务好的七里河做网站的公司定做!
字符串拷贝
char* strcpy(char* strDest,const char* strSrc) { assert(strDest!=NULL && strSrc!=NULL); char* strTmp = strDest; while(*strSrc!='\0') { *strDest++ = *strSrc++; } strDest = '\0'; return strTmp; }
内存拷贝
void * memcpy(void* strDest,void* strSrc,size_t size) { assert(strDest!=NULL && strSrc != NULL); void* strTmp = strDest; //考虑内存重叠情况 类似memmove if (strDest<=strSrc || (char*)strDest >= (char*)strSrc+size) { while(size--) { *(char*)strDest = *(char*)strSrc; strDest = (char*)strDest + 1; strSrc = (char*)strSrc + 1; } } else { strDest = (char*)strDest+size-1; strSrc = (char*)strSrc +size-1; while(size--) { *(char*)strDest = *(char*)strSrc; strDest = (char*)strDest-1; strSrc = (char*)strSrc-1; } } return strTmp; }
求字符串大小
int strlen(const char*strSrc) { assert(strSrc!= NULL); int len = 0; while((*strSrc++) != '\0') ++len; return len; }
两字符串连接
char* strcat(char* strDest,const char* strSrc) { assert((strDest != NULL) && (strSrc != NULL)); char* strTmp = strDest; while(*strDest != '\0') ++strDest; while(*strDest++ = *strSrc++) ; *strDest++ = '\0'; return strDest; }
字符串转×××数处理
int myAtoi(char* strSrc) { int iValue = 0; int flag=0; while (*strSrc == ' ') { strSrc++; } if(*strSrc == '-') { flag = -1; } else if(*strSrc == '+') { flag = 1; } else if(*strSrc > '9' || *strSrc < '0') { return 0; } while(*strSrc>='0' && *strSrc <= '9' && *strSrc ) { iValue = iValue*10 + *strSrc -'\0'; strSrc++; } if(flag == 0) iValue = iValue*(-1); return iValue; }
判断输入的是否是回文
bool isPalindrome(char* input) { if(input == NULL) return false; char* strBegin = input; char* strEnd = input+strlen(input)-1; while (strBegin < strEnd) { if(*strBegin++ != *strEnd--) return false; } return true; }
把一个char组成的字符串循环右移n个 void loopMove(char* pStr,int steps) { int nLen = strlen(pStr); if(nLen <= 0 || steps == 0) return; int nStep = steps % nLen; if(nStep == 0) return; char strTmp[128]; memcpy(strTmp,pStr+nLen-nStep,nStep); memcpy(strTmp+nStep,pStr,nLen-nStep); memcpy(pStr,strTmp,nLen); }