#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
char *my_strchr(const char *dst, char c) //由於我們只是查找,不修改這個字符串,所以將dst聲明成const
{
assert(dst); //先對字符串進行斷言
const char *pdst = dst; //將字符串其實位置保存下來
while (*pdst)
{
if (*pdst == c) //找到就返回這個地址
return (char *)pdst;
else
pdst++;
}
return NULL; //沒找到返回空
}
int main()
{
char c=0;
char arr[40]={0};
char * = NULL;
scanf("%c", &c);
scanf("%s", arr);
str=my_strchr(arr, c);
printf("%#p\n",*str);
system("pause");
return 0;
}
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
char *my_strrchr(const char *src, char c) //由於我們只是查找,不修改這個字符串,所以將src聲明成const
{
assert(src); //<span style="font-family:Arial,Helvetica,sans-serif">先對字符串進行斷言</span>
const char *psrc = src;
char *dst = NULL;
while (*psrc)
{
if (*psrc == c)
dst =(char *) psrc; //用標籤記錄找到的位置
psrc++;
}
return dst;
}
int main()
{
char c = 0;
char arr[40];
char *place = NULL;
scanf("%c%s", &c, arr);
place = my_strrchr(arr, c);
printf("%#p\n",place);
system("pause");
return 0;
}
//strrstr庫裏面沒有,我們仿照strchr這個函數的功能實現一個strrstr
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
char *my_strrstr(const char *dst, const char *src)
{
assert(dst);
assert(src);
const char *pdst = dst;
const char *psrc = src;
char *right= NULL;
while (*dst)
{
while (*pdst == *psrc)
{
if (*pdst== '\0') //如果*pdst爲‘\0'則已經找到最後一個
return right=(char *)dst;
else
{
pdst++;
psrc++;
}
}
if (*psrc == '\0') //找到一個,但不確定是不是最後一個
right = (char *)dst;
pdst = ++dst;
psrc = src;
}
return right;
}
int main()
{
char arr1[50] = { 0 };
char arr2[40] = { 0 };
char *place = NULL;
scanf("%s%s",arr1, arr2);
place = my_strrstr(arr1, arr2);
printf("%#p\n",place); //輸出這個地址
system("pause");
return 0;
}
strncat()函數 首先要說的是strncat函數 函數原型: char *strncat(char *dest,const
char *src,size_t len);
strncat就是把src中的最多len個字符複製到目標數組的後面,但是,strncat總是在結果的字符加一個NUL字節。
//實現strncat函數
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
char *my_strncat(char * str1,const char* str2,size_t n)
{
assert(str1);
assert(str2);
char *ret = str1;
while (*ret)
{
ret++;
}
while (n)
{
*ret = *str2;
ret++;
str2++;
n--;
}
*ret = '\0';
return str1;
}
int main()
{
char str1[20] = "abcd";
char *str2 = "132";
my_strncat(str1, str2,8);
printf("%s\n", str1);
system("pause");
return 0;
}
strncpy()函數 函數原型:char *strncpy(char *dest,const char *src,size_t
len); strncpy把源字符串的字符複製到目標數組,strncpy()會將字符串src前n個字符拷貝到字符串dest。
不像strcpy(),strncpy()不會向dest追加結束標記’\0’,這就引發了很多不合常理的問題,將在下面的示例中說明。
它總是正好向dest寫入len個字符,如果strlen(src)的值小於len,dest數組就用額外的NUL字節填充到len長度。如果stelen(src)的值大於或者等於len,那麼只有len個字符被複制到dest中。注意:它的結果將不會以NUL字節結尾。
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
char *my_strncpy(char *str1, const char *str2, int n)
{
assert(str1);
assert(str2);
char *ret = str1;
while ((n>0)&&(*str2))
{
*ret++ = *str2++;
n--;
}
*ret = '\0';
return str1;
}
int main()
{
char str1[20] = "abcd";
char *str2 = "cb78979";
my_strncpy(str1, str2, 3);
printf("%s", str1);
system("pause");
return 0;
}
strncmp()函數
strcmp函數用來比較兩個字符串,但它比較len個字節,如果兩個字符串在第len個字符之前存在不相等的字符,也就是說,如果字符串s1與s2的前size個字符相同,函數返回值爲0
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
int my_strncmp(const char *str1,const char* str2,int n)
{
assert(str1);
assert(str2);
while (n-1)
{
if (*str1&&*str2&&*str1 == *str2)
{
str1++;
str2++;
n--;
}
else
break;
}
return *str1 - *str2;
}
int main()
{
char str1[20] = "abcd";
char *str2 = "cbce";
int ret = my_strncmp(str1, str2, 1);
if (ret > 0)
printf("字符串不相等");
else if (ret < 0)
printf("字符串不相等");
else
printf("字符串相等");
system("pause");
return 0;
}