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

相关推荐
地平线开发者1 小时前
征程 6M 部署 Omnidet 感知模型
算法·自动驾驶
秋说1 小时前
【PTA数据结构 | C语言版】线性表循环右移
c语言·数据结构·算法
浩瀚星辰20242 小时前
图论基础算法:DFS、BFS、并查集与拓扑排序的Java实现
java·算法·深度优先·图论
芯岭技术3 小时前
MS32C001-C单片机,32位ARM M0+内核,宽电压、低功耗、小封装。
c语言·arm开发·单片机
oioihoii4 小时前
C++随机打乱函数:简化源码与原理深度剖析
开发语言·c++·算法
不知名。。。。。。。。4 小时前
分治算法---快排
算法
minji...5 小时前
数据结构 算法复杂度(1)
c语言·开发语言·数据结构·算法
凌肖战5 小时前
力扣网编程150题:加油站(贪心解法)
算法·leetcode·职场和发展
吃着火锅x唱着歌5 小时前
LeetCode 3306.元音辅音字符串计数2
算法·leetcode·c#
不見星空5 小时前
【leetcode】1751. 最多可以参加的会议数目 II
算法·leetcode