字符串函数的使用和模拟实现(四)

#include<string.h>

int main()

{

char arr1[30]={"kongchao"};

char arr2[30]={"hello world"};

strncpy(arr2,arr1,9);//拷贝九个是因为第九个字节是'\0'

printf("%s",arr2);

return 0;

}

strncpy函数模拟实现

#include<stdio.h>

#include<assert.h>

charstrncpy(chardest,char*src,int k)

{

assert(dest&&src);//判断非空

char*nb=dest;

while((*dest++ = *src++)&&(k--))

{

;

}

return nb;

}

int main()

{

char arr1[30]={"ni shi hei ma"};

char arr2[30]={"ni na nie"};

int k=0;

printf("请输入你要拷贝的字节数");//空格不算个数里面

scanf("%d",&k);

char*ret=my_strncpy(arr1,arr2,k);

printf("%s",arr1);//写ret也是一样的(都是arr1的首元素地址)

return 0;

}

2.strncat函数


函数的参数形式char*strncat(char*dest,const char*src,size_t num)

这个函数的形式简直和上面那个strncpy一模一样(他们的模拟实现也是基本一样的,

可以说strncpy是strncat的子集)注如果连接的个数大于源头个数,则还是连接源头个数。

函数使用:

#include<stdio.h>

#include<string.h>

int main()

{

char arr2[30]={"zhangdahou"};

char arr1[30]={"xiaoshihou"};

strncat(arr1,arr2,6);//连接6个

printf("%s",arr1);

return 0;

}

注意如果是这种strncat(arr1+n,arr2,8);其中n小于等于arr1的长度,则arr2还是连接到arr1后面,若大于则报错

strncat函数模拟实现

#include<stdio.h>

#include<assert.h>

charmy_strncat(chardest,char*src)

{

assert(dest&&src);

char*ret=dest;//记下开始的位置

while(*++dest)

{

;

}

while(*dest++=*src++)

{

;

}

return ret;

}

int main()

{

char arr1[50]={"kong chao yao "};

char arr2[30]={"cheng wei da niu"};

char*kc= my_strncat(arr1,arr2);

printf("%s",kc);

return 0;

}

3.strncmp函数


函数的参数形式int strncmp ( const char * str1, const char * str2 ,size_t num);

size_t表示无符号整形,num表示字符比较的个数,返回类型str1>str2返回大于0的数

str1=str2返回0,str1<str2,返回小于0的数。(vs默认返回1 0 -1)。

函数的使用

#include<stdio.h>

#include<string.h>

int main()

{

char arr1[4] = { "asdf" };

char arr2[4] = { "ase" };

int dd=strncmp(arr1, arr2, 3);//arr1和arr2比较

printf("%d\n", dd);//结果是小于0的随机数

return 0;

}

strncmp函数模拟实现

#include<stdio.h>

#include<assert.h>

int my_strncmp(charstr1, charstr2,int k)

{

assert(str1&&str2);

while ((*str1== *str2) && (k--))

{

str1++; str2++;

if ((*str1 == '\0') || (k == 0))

{

return 0;

}

}

return *str1 - *str2;

}

int main()

{

char arr1[10] = { "abcdega" };

char arr2[10] = { "abcdeg" };

int kc = my_strncmp(arr1, arr2, 7);

printf("%d\n", kc);

return 0;

**最后的最后给个一键三连呗,**学有所成呀

最后

资料过多,篇幅有限

自古成功在尝试。不尝试永远都不会成功。勇敢的尝试是成功的一半。

return *str1 - *str2;

}

int main()

{

char arr1[10] = { "abcdega" };

char arr2[10] = { "abcdeg" };

int kc = my_strncmp(arr1, arr2, 7);

printf("%d\n", kc);

return 0;

**最后的最后给个一键三连呗,**学有所成呀

最后

[外链图片转存中...(img-D9KF6Uxb-1718600564819)]

[外链图片转存中...(img-9RWH6rVA-1718600564820)]

资料过多,篇幅有限

自古成功在尝试。不尝试永远都不会成功。勇敢的尝试是成功的一半。

相关推荐
2401_857439691 小时前
SSM 架构下 Vue 电脑测评系统:为电脑性能评估赋能
开发语言·php
SoraLuna2 小时前
「Mac畅玩鸿蒙与硬件47」UI互动应用篇24 - 虚拟音乐控制台
开发语言·macos·ui·华为·harmonyos
xlsw_2 小时前
java全栈day20--Web后端实战(Mybatis基础2)
java·开发语言·mybatis
Dream_Snowar3 小时前
速通Python 第三节
开发语言·python
XH华3 小时前
初识C语言之二维数组(下)
c语言·算法
南宫生4 小时前
力扣-图论-17【算法学习day.67】
java·学习·算法·leetcode·图论
不想当程序猿_4 小时前
【蓝桥杯每日一题】求和——前缀和
算法·前缀和·蓝桥杯
高山我梦口香糖4 小时前
[react]searchParams转普通对象
开发语言·前端·javascript
落魄君子4 小时前
GA-BP分类-遗传算法(Genetic Algorithm)和反向传播算法(Backpropagation)
算法·分类·数据挖掘
菜鸡中的奋斗鸡→挣扎鸡4 小时前
滑动窗口 + 算法复习
数据结构·算法