溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

字符串類函數(shù)的實(shí)現(xiàn)是怎樣的

發(fā)布時(shí)間:2021-10-14 14:01:45 來(lái)源:億速云 閱讀:109 作者:柒染 欄目:編程語(yǔ)言

本篇文章給大家分享的是有關(guān)字符串類函數(shù)的實(shí)現(xiàn)是怎樣的,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

char *strcpy(char *strDest ,const char * strSrc )

{

if(strDest == NULL || strSrc == NULL)

return 0;

char *address = strSrc;

while((*strDest++ = *strSrc++) != '\0')

NULL;

return addressl;

}

//字符串比較函數(shù),相等返回0,s1大返回正整數(shù),s2大返回負(fù)整數(shù)
int mystrcmp(const char *s1,const char *s2)
{
    while(*s1!='/0'&&*s2!='/0'&&(*s1==*s2))  s1++,s2++;
    return (*s1)-(*s2);
}

//字符串長(zhǎng)度函數(shù),長(zhǎng)度不包括結(jié)尾的'/0'
int mystrlen(const char *s)
{
int res = 0;
while(*s++!='/0')
   res++;
return res;
}

//字符串連接函數(shù)
char *mystrcat(char *source,const char *dest)
{

if(source ==NULL
|| dest == NULL)

return 0;
char *s = source;
while(*s!='/0')s++;
while(*dest!='/0')*s++ = *dest++;
*s='/0';
return source;
}

//字符串轉(zhuǎn)換小寫(xiě)字母函數(shù)
char *mystrlwr(char *source)
{
   char *s = source;
   do 
   {
   if(*s>='A'&&*s<='Z')
      *s+=32;
   } while (*s++!='/0');
   return source;
}
//字符串轉(zhuǎn)換大寫(xiě)字母函數(shù)
char *mystrupr(char *source)
{
char *s = source;
do 
{
   if(*s>='a'&&*s<='z')
    *s-=32;
} while (*s++!='/0');
    return source;
}

/字符串倒轉(zhuǎn)函數(shù)
char *mystrrev(char *source)
{
char *s1 = source,*s2 = source,temp;
while(*s2!='/0')s2++;
if(s1!=s2)s2--;//找中值,交換分界點(diǎn)
while(s1<s2)temp = *s1,*s1 = *s2,*s2 = temp,s1++,s2--;
return source;
}

//字符串查找指定字符串的第一次出現(xiàn),沒(méi)有出現(xiàn)返回NULL,出現(xiàn)則返回出現(xiàn)的位置
static const char* _strstr(const
char* s1, const char* s2)
{
assert(s2 && s1);
const char* p=s1, *r=s2;
while(*p!="\0”)
{
while(*p++==*r++);
if(*r=="\0”)
return p;
else
{
r=s2;
p=++s1;
}
}
return NULL;
}

  1. //strSrc指向的字符串循環(huán)右移n個(gè)字符后保存到strDest中并返回

  2. char * circulate_right_move(char *strDest,const char *strSrc,const int n)

  3. {

  4.     assert( (strDest != NULL) && (strSrc != NULL));

  5.     

  6.     char * address = strDest;

  7.     int len = strlen(strSrc);

  8.     int offset = n % len;

  9.     

  10.     strSrc += (len - offset);

  11.     

  12.     for(;(*strDest = *strSrc) != '\0';strDest++,strSrc++);

  13.     

  14.     strSrc -= len;    

  15.     

  16.     for(int i = 0; i < len - offset; i++)

  17.     {

  18.         *strDest = *strSrc;

  19.         strDest++;

  20.         strSrc++;

  21.     }

  22.     

  23.     *strDest = '\0';


  24.     return address;

  25. }

感覺(jué)可以用CMP算法優(yōu)化。

以上就是字符串類函數(shù)的實(shí)現(xiàn)是怎樣的,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI