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;
}

相关推荐
晨非辰2 小时前
《剑指Offer:单链表操作入门——从“头删”开始破解面试》
c语言·开发语言·数据结构·c++·笔记·算法·面试
啊我不会诶5 小时前
24ICPC成都站补题
数据结构·算法
2401_841495648 小时前
【计算机视觉】基于数学形态学的保留边缘图像去噪
人工智能·python·算法·计算机视觉·图像去噪·数学形态学·边缘保留
十八岁讨厌编程8 小时前
【算法训练营Day30】动态规划part6
算法·动态规划
CoderYanger8 小时前
优选算法-双指针:2.复写零
java·后端·算法·leetcode·职场和发展
王夏奇9 小时前
C语言中#pragma的用法
c语言·开发语言
charlie1145141919 小时前
理解C++20的革命特性——协程支持2:编写简单的协程调度器
c++·学习·算法·设计模式·c++20·协程·调度器
hadage2339 小时前
--- 常见排序算法汇总 ---
算法·排序算法
Mrs.Gril9 小时前
目标检测:yolov7算法在RK3588上部署
算法·yolo·目标检测
WWZZ202511 小时前
ORB_SLAM2原理及代码解析:单应矩阵H、基础矩阵F求解
线性代数·算法·计算机视觉·机器人·slam·基础矩阵·单应矩阵