strcpy、strncpy、strcat、strncat、strcmp、strstr字符串函数的使用和模拟

strcpy的使用和模拟(作用)

将一个字符串的内容复制到另外一个字符串中代替掉。

strcpy的使用效果

#include <stdio.h>
#include <string.h>

int main ()
{
  char str1[]="Sample string";
  char str2[40];
  char str3[40];
  strcpy (str2,str1);
  strcpy (str3,"copy successful");
  printf ("str1: %s\nstr2: %s\nstr3: %s\n",str1,str2,str3);
  return 0;
}

strcpy效果模拟

strcpy函数的使用参数

接下来我们对strcpy函数进行模拟

//strcpy只用于字符串复制,遇到'\0'时停止,还会复制字符串的结束符'\0';
//所以源字符串必须以'\0'结束,也会将源字符串的'\0'拷贝到目标空间
#include<stdio.h>
#include<assert.h>
 char*my_strcpy(char*dest,const char*str)
{
	 assert(dest && str);
	 char* ret = dest;
	 while (*dest++ = *str++)//*dest++先使用dest后使用++
	 {
		 ;
	 }
	 return ret;
}
int main()
{
	char arr1[] = "I LOVE YOU";
	char arr2[] = "he he";
	my_strcpy(arr1, arr2);
	printf("%s", arr1);

	return 0;
}

strncpy的使用和模拟

strncpy的使用效果

#include<stdio.h>
#include<string.h>
int main()
{
	char str1[] = "abcdef";
	char str2[] = "yes";
	strncpy(str1, str2, 3);
	printf("%s", str1);
	return 0;
}

strncpy效果模拟

strncpy函数的使用参数

接下来我们对strncpy函数进行模拟

#include<stdio.h>
#include<string.h>
char* my_strncpy(char* str1, const char* str2, size_t n)
{
	if (str1 == NULL || str2 == NULL)//判空
		return 0;
	char* start = str1;//记录目标数组首地址
	while (n && (*str1++ = *str2++))//复制字符串,并考虑n小于或等于被拷贝字符串数目的情况
	{
		n--;
	}
	if (n)//如果n大于被拷贝字符串数目,须将除被拷贝字符的其他内容用空字符进行补充
	{
		while (n)
		{
			*str1++ = '\0';
			n--;
		}
	}
	return start;
}
int main()
{
	char str1[] = "abcdef";
	char str2[] = "yes";
	my_strncpy(str1, str2, 2);
	printf("%s", str1);
	return 0;
}

strcat的使用和模拟(作用)

将一个字符串中的内容追加到另外一个字符串后面

strcat的使用效果

#include <stdio.h>
#include <string.h>

int main ()
{
  char str[80];
  strcpy (str,"these ");
  strcat (str,"strings ");
  strcat (str,"are ");
  strcat (str,"concatenated.");
  puts (str);
  return 0;
}

strcat效果模拟

strcat函数的使用参数

接下来我们对strcat函数进行模拟

#include<stdio.h>
#include<assert.h>
char* my_strcat(char* dest, const char* arr)
{
	char* ret = dest;
	assert(dest && arr);
	while (*dest != '\0')
		dest++;
	while (*dest++ = *arr++)
	{
		;
	}
	return ret;
}
int main()
{
	char str1[20] = "I LOVE YOU";
	char str2[] = "abcd";
	my_strcat(str1, str2);
	printf("%s\n", str1);
	return 0;
}

strncat的使用和模拟

strncat的使用效果

#include<stdio.h>
#include<string.h>
#include<assert.h>
int main()
{
	char str1[20] = "abcdef";
	char str2[] = "yes";
	//这里是特别需要注意的,在创建str1的空间的时候,我们需要给str1创建足够大的空间
	//以此来容纳str1和str2的空间
	strncat(str1, str2, 4);
	printf("%s\n", str1);
	return 0;
}

strncat效果模拟

strncat函数的使用参数

接下来我们对strncat函数进行模拟

#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strncat(char*str1, const char*str2, size_t num)
{
	assert(str1 && str2);
	char* start = str1;
	while (*str1)
	{
		str1++;
	}
	while (num--)
	{
		*str1++ = *str2++;
	}
	*str1 = '\0';
	return start;
}
int main()
{
	char str1[20] = "abcdef";
	char str2[] = "yes";
	my_strncat(str1, str2, 2);
	printf("%s\n", str1);
	return 0;
}

strcmp的使用和模拟(作用)

strcmp函数比较两个字符串的大小

大于则返回大于0的数字,小于返回小于0的数字,等于则返回0。

strcmp的使用效果

#include <stdio.h>
#include <string.h>

int main ()
{
  char key[] = "apple";
  char buffer[80];
  do {
     printf ("Guess my favorite fruit? ");
     fflush (stdout);
     scanf ("%79s",buffer);
  } while (strcmp (key,buffer) != 0);
  puts ("Correct answer!");
  return 0;
}

strcmp效果模拟

接下来我们对strcmp函数进行模拟

#include<stdio.h>
#include<assert.h>
int my_strcmp(const char* str1, const char* str2)
{
	assert(str1 && str2);
	while (*str1 == *str2)
	{
		if (*str1 == '\0')
		{
			return 0;
		}
		str1++;
		str2++;
	}
	return *str1 - *str2;
}
int main()
{
	char arr1[] = "abcdef";
	char arr2[] = "abdcef";
	int ret = my_strcmp(arr1, arr2);
	printf("%d ", ret);
	return 0;

strstr的使用和模拟(作用)

strstr的使用效果

从字符串1中找到字符串2相同的字符串,然后输出字符串1中从字符串2相同位置开始的字符到'\0',如果没有就不输出

#include <stdio.h>
#include<string.h>
int main()
{
	char str[] = "abcdefabcdef";
	char* p = "fab";
	char* ret = strstr(str, p);
	if (ret == NULL)
	{
		printf("不存在");
	}
	else
	{
		printf("%s", ret);
	}
	return 0;
}

strstr效果模拟

接下来我们对strstr函数进行模拟

#include <stdio.h>
#include<string.h>
#include<assert.h>
char* my_strstr(const char* str, const char* str1)
{
	assert(str && str1);
	char* pc = str;
	const char* s1 = NULL;
	const char* s2 = NULL;
	if (*str1 == '\0')
		return str;
	while (*pc != '\0')
	{
		s1 = pc;
		s2 = str1;
		while (*s1 && *s2 && *s1 == *s2)
		{
			s1++;
			s2++;
		}
		if (*s2 == '\0')
			return pc;
		pc++;
	}
	return NULL;
}
int main()
{
	char str[] = "abbbdefabcdef";
	char* p = "bbd";
	const char* ret = my_strstr(str, p);
	printf("%s ", ret);
	return 0;
}

看到这里的小伙伴,帮忙点个赞,谢谢!

相关推荐
用户0099383143013 分钟前
代码随想录算法训练营第十三天 | 二叉树part01
数据结构·算法
shinelord明7 分钟前
【再谈设计模式】享元模式~对象共享的优化妙手
开发语言·数据结构·算法·设计模式·软件工程
დ旧言~13 分钟前
专题八:背包问题
算法·leetcode·动态规划·推荐算法
嵌入式科普30 分钟前
十三、从0开始卷出一个新项目之瑞萨RZN2L串口DMA接收不定长
c语言·stm32·瑞萨·e2studio·rzn2l
_WndProc31 分钟前
C++ 日志输出
开发语言·c++·算法
薄荷故人_32 分钟前
从零开始的C++之旅——红黑树及其实现
数据结构·c++
努力学习编程的伍大侠44 分钟前
基础排序算法
数据结构·c++·算法
XiaoLeisj1 小时前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
Jasmine_llq2 小时前
《 火星人 》
算法·青少年编程·c#