模拟实现字符串函数(6):strncat

1.函数介绍

翻译一下:就是当源字符串长度小于num时会只追加源字符串的最大长度,大于num时正常追加

2.思路分析

1.首先将dest的指针保留用于返回,随后遍历到dest的末尾;

2.判断一下num是否大于src的长度,如果小于的话,将src遍历追加完即可。

复制代码
char* my_strncat(char* dest, char* src, size_t num)
{
	char* ret = dest;
	while (*dest)
	{
		dest++;
	}
	//源字符串长度大于num
	if (strlen(src) >= num)
	{
		while (num--)
		{
			*dest++ = *src++;
		}
	}
	else
	{
		while (*src != '\0')
		{
			*dest++ = *src++;
		}

	}
	return ret;
}

int main()
{
	char str1[30] = "abcdefghij";
	char str2[] = "aaattttt";
	my_strncat(str1, str2, 5);
	printf("%s\n", str1);
	return 0;
}
相关推荐
小龙报14 小时前
《算法通关指南C++编程篇 --- 初阶函数递归专题》
c语言·开发语言·c++·算法·创业创新·学习方法·visual studio
星轨初途14 小时前
《数据结构二叉树之堆 —— 优先队列与排序的高效实现(2)(下)》
c语言·开发语言·数据结构·经验分享·笔记·性能优化
Shylock_Mister14 小时前
ARM与x86交叉编译实战排错指南
linux·c语言·arm开发
高山有多高15 小时前
堆应用一键通关: 堆排序 +TOPk问题的实战解析
c语言·数据结构·c++·算法
程序猿追15 小时前
Ascend C编程范式总结:与CUDA的异同对比
c语言·开发语言·算法
晨非辰17 小时前
【数据结构初阶系列】归并排序全透视:从算法原理全分析到源码实战应用
运维·c语言·数据结构·c++·人工智能·python·深度学习
松涛和鸣1 天前
11.C 语言学习:递归、宏定义、预处理、汉诺塔、Fibonacci 等
linux·c语言·开发语言·学习·算法·排序算法
鑫—萍1 天前
C/C++精品算法——双指针(1)
c语言·c++·算法
智者知已应修善业1 天前
【51单片机:两边向中间流水:即两边先点亮然后熄灭,次边的点亮再熄灭,直到最中间的两个点亮再熄灭,然后重复动作。】2023-3-4
c语言·c++·经验分享·笔记·嵌入式硬件·算法·51单片机
Vanranrr1 天前
车机项目中的 Widget 设计反思:从“能用”到“好用”的改进方向
c语言·c++·架构