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

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

相关推荐
盼海1 小时前
排序算法(五)--归并排序
数据结构·算法·排序算法
网易独家音乐人Mike Zhou4 小时前
【卡尔曼滤波】数据预测Prediction观测器的理论推导及应用 C语言、Python实现(Kalman Filter)
c语言·python·单片机·物联网·算法·嵌入式·iot
搬砖的小码农_Sky7 小时前
C语言:数组
c语言·数据结构
Swift社区8 小时前
LeetCode - #139 单词拆分
算法·leetcode·职场和发展
Kent_J_Truman8 小时前
greater<>() 、less<>()及运算符 < 重载在排序和堆中的使用
算法
先鱼鲨生9 小时前
数据结构——栈、队列
数据结构
一念之坤9 小时前
零基础学Python之数据结构 -- 01篇
数据结构·python
IT 青年9 小时前
数据结构 (1)基本概念和术语
数据结构·算法
熬夜学编程的小王9 小时前
【初阶数据结构篇】双向链表的实现(赋源码)
数据结构·c++·链表·双向链表
Dong雨9 小时前
力扣hot100-->栈/单调栈
算法·leetcode·职场和发展