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

#include<string.h>

int main()

{

char arr130={"kongchao"};

char arr230={"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 arr130={"ni shi hei ma"};

char arr230={"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 arr230={"zhangdahou"};

char arr130={"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 arr150={"kong chao yao "};

char arr230={"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 arr14 = { "asdf" };

char arr24 = { "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 arr110 = { "abcdega" };

char arr210 = { "abcdeg" };

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

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

return 0;

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

最后

资料过多,篇幅有限

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

return *str1 - *str2;

}

int main()

{

char arr110 = { "abcdega" };

char arr210 = { "abcdeg" };

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

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

return 0;

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

最后

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

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

资料过多,篇幅有限

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

相关推荐
ylscode4 小时前
黑客利用 GHOSTYNETWORKS 和 OMEGATECH 托管 JS 恶意软件基础设施
开发语言·安全·php·安全威胁分析
莫等闲-4 小时前
leetcode42. 接雨水 leetcode84.柱状图中最大的矩形
数据结构·c++·算法·leetcode
爱吃生蚝的于勒4 小时前
QT开发第二章——信号和槽
c语言·开发语言·c++·qt
unicrom_深圳市由你创科技4 小时前
历史数据存储量太大,怎么处理?数据压缩/归档策略?
算法
浅念-4 小时前
LeetCode 记忆化搜索 刷题总结
数据结构·算法·leetcode·职场和发展·深度优先·dfs
xcLeigh4 小时前
Python入门:Python3 operator模块全面学习教程
开发语言·python·学习·教程·python3·operator
大叔带刺4 小时前
使用python创建自己的专属星座签名APP:Name2Constell
开发语言·python·pygame
z落落4 小时前
C# 类与对象、字段、静态与非静态+四大访问修饰符
开发语言·c#
思麟呀4 小时前
C++工业级日志项目(八)最终上层接口
开发语言·c++
菜菜的顾清寒4 小时前
力扣HOT100(44)对称二叉树
数据结构·算法·leetcode