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

相关推荐
yuyousheng几秒前
CMake详解
c语言
lynnlovemin1 分钟前
从暴力到高效:C++ 算法优化实战 —— 排序与双指针篇
java·c++·算法
jinxinyuuuus6 分钟前
快手在线去水印:短链解析、API逆向与视频流的元数据重构
前端·人工智能·算法·重构
Flash.kkl11 分钟前
优先算法专题十五——BFS_FloodFill
算法·宽度优先
高洁0118 分钟前
向量数据库拥抱大模型
python·深度学习·算法·机器学习·transformer
慕容青峰21 分钟前
牛客小白月赛 103 C 题题解
c++·算法·sublime text
小龙报21 分钟前
【算法通关指南:算法基础篇(四)】二维差分专题:1.【模板】差分 2.地毯
c语言·数据结构·c++·深度学习·神经网络·算法·自然语言处理
立志成为大牛的小牛22 分钟前
数据结构——五十八、希尔排序(Shell Sort)(王道408)
数据结构·学习·程序人生·考研·算法·排序算法
代码游侠28 分钟前
学习笔记——文件I/O
linux·数据库·笔记·学习·算法