strcat及其模拟实现

#define _CRT_SECURE_NO_WARNINGS

strcat 追加字符串

str = "string"(字符串)
cat = "concatenate"(连接 / 追加)

char* strcat(char* destination, const char* source);

strcat的应用

方法一:

#include<stdio.h>
#include<string.h>
int main()
{
char arr1[31] = "Welcome to PKU, ";

//arr1原字符数 + arr2原字符数 + arr2[]中的结束符'\0' 刚好等于 总共需要的空间 31
char arr2[] = "Chen Xianglin.";
strcat(arr1, arr2);
printf("%s\n", arr1);

return 0;
}

方法二:

#include<stdio.h>
#include<string.h>
int main()
{
//char arr1[45] = "Welcome to PKU, ";
char arr1[45] = "Welcome to PKU, \0dd";
strcat(arr1, "Chen Xianglin.");
printf("%s\n", arr1);

//由此可见,即便是目标字符串中包含'\0',源字符串也依旧会追加在目标字符串之后。
//不过,也同时可知,当目标字符串中出现多个'\0'时,源字符串会从第一个'\0'开始追加。

return 0;
}

strcat模拟实现

#include<stdio.h>
#include<assert.h>

char* my_strcat(char* dest, const char* sour)
{
assert(dest && sour);
char* ret = dest;

//找目标空间的第一个出现的'\0'
while (*dest)
dest++;
//追加
while (*dest++ = *sour++);
return ret;
}
int main()
{
char arr1[45] = "Welcome to PKU, \0, Chen Xianglin.";
char arr2[] = "Chen Xianglin.";
my_strcat(arr1, arr2);
printf("%s\n", arr1);
return 0;
}

my_strcat代码整理

#include<stdio.h>
#include<assert.h>

char* my_strcat(char* dest, const char* str)
{
assert(dest && str);
char* ret = dest;

//找第一个'\0'
while (*dest)
dest++;
//追加
while (*dest++ = *str++);
return ret;
}
int main()
{
char arr1[31] = "Welcome to PKU, ";
char arr2[] = "Chen Xianglin.";
my_strcat(arr1, arr2);
printf("%s\n", arr1);
return 0;
}

相关推荐
NAGNIP7 小时前
一文搞懂机器学习中的特征降维!
算法·面试
NAGNIP8 小时前
一文搞懂机器学习中的特征构造!
算法·面试
Learn Beyond Limits8 小时前
解构语义:从词向量到神经分类|Decoding Semantics: Word Vectors and Neural Classification
人工智能·算法·机器学习·ai·分类·数据挖掘·nlp
你怎么知道我是队长8 小时前
C语言---typedef
c语言·c++·算法
带土19 小时前
5. enum(枚举)关键字在C/C++中的作用
c语言·c++
Qhumaing10 小时前
C++学习:【PTA】数据结构 7-1 实验7-1(最小生成树-Prim算法)
c++·学习·算法
Z1Jxxx11 小时前
01序列01序列
开发语言·c++·算法
汽车仪器仪表相关领域13 小时前
全自动化精准检测,赋能高效年检——NHD-6108全自动远、近光检测仪项目实战分享
大数据·人工智能·功能测试·算法·安全·自动化·压力测试
Doro再努力13 小时前
【数据结构08】队列实现及练习
数据结构·算法