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

相关推荐
STY_fish_201239 分钟前
手拆STL
java·c++·算法
小纭在努力43 分钟前
【算法设计与分析】实验——改写二分搜索算法,众数问题(算法分析:主要算法思路),有重复元素的排列问题,整数因子分解问题(算法实现:过程,分析,小结)
数据结构·python·学习·算法·算法设计与分析·实验报告·实验
芜湖xin2 小时前
【题解-洛谷】B4278 [蓝桥杯青少年组国赛 2023] 简单算术题
算法·
理智的灰太狼2 小时前
题目 3298: 蓝桥杯2024年第十五届决赛真题-兔子集结
算法·职场和发展·蓝桥杯
kingmax542120085 小时前
【洛谷P9303题解】AC- [CCC 2023 J5] CCC Word Hunt
数据结构·c++·算法·广度优先
白熊1885 小时前
【机器学习基础】机器学习入门核心算法:XGBoost 和 LightGBM
人工智能·算法·机器学习
bai_lan_ya6 小时前
数据结构-排序-排序的七种算法(2)
数据结构·算法·排序算法
全域智图7 小时前
元胞自动机(Cellular Automata, CA)
人工智能·算法·机器学习
珂朵莉MM7 小时前
2022 RoboCom 世界机器人开发者大赛-本科组(省赛)解题报告 | 珂学家
人工智能·算法·职场和发展·深度优先·图论
独家回忆3647 小时前
每日算法-250601
数据结构·算法