首页 > 其他分享 >C语言 模拟实现字符串函数 看着一篇够了

C语言 模拟实现字符串函数 看着一篇够了

时间:2022-11-03 00:48:32浏览次数:78  
标签:dist ++ C语言 char source 字符串 return 模拟 const

C语言 模拟实现字符串操作的库函数

求字符串长度 strlen

思路
1.如果碰到\0就代表字符串已经到了末尾

size_t my_strlen(const char* str)
{
	assert(str!=NULL);
	//指针版本
	/*const char* start = str;
	const char* end = str;
	while (*end!='\0')
	{
		end++;
	}
	return end-start;*/
	
	//递归实现
	if (*str == '\0')
	{
		return 0;
	}
	return 1 + my_strlen(str+1);
}

字符串拷贝函数 strcpy实现

char* my_strcpy(char* dist, const char* source)
{
	assert(dist && source);
	char* ret = dist;
	while ((*dist++ = *source++)!='\0')
	{
		;
	}
	return ret;
}
char* my_strncpy(char* dist,const char* source,size_t num)
{
	// 存储dist首地址
	char* start = dist;
	// 1.如果num为0 不需要拷贝
	// 2.如果拷贝的到source \0 结束拷贝
	while (num && (*dist++ = *source++) != '\0')
	{
		// 每拷贝一个字符 减一次 
		num--;
	}
	//如果没拷贝完num个 继续拷贝 末尾追加\0
	if (num)
	{
		while (--num)
		{
			*dist = '\0';
		}
	}
	return start;
}

字符串拼接函数 strcat strncat

//修改了值的过程 dist一直在++ 指向的就不是原起始地址
char* my_strcat(char* dist, const char* source)
{
	//注意:保留目标字符串的开始地址
	char* ret = dist;
	assert(dist && source);
	//1.找到目标字符串的\0
	while (*dist)
	{
		dist++;
	}
	//2.追加源字符串,包含\0
	while ((*dist++ = *source++)!='\0')
	{
		;
	}
	return ret;// 返回目标空间的起始地址
}

//手动添加\0
char* my_strncat(char* dist, char* source, size_t num)
{
	assert(dist && source);
	char* start = dist;
	// 知道目标字符串的\0 才可以开始拷贝
	// 会跳过\0
	while (*dist++)
	{
		;
	}
	dist--;
	while (num--)
	{
		if ((*dist++ = *source++) == 0)
			return start;
	}
	*dist = '\0';
	return start;


}

字符串比较函数 strcmp strncmp

int my_strcmp(const char* dist, const char* source)
{
	//判断指针有效性
	if (dist == NULL || source == NULL)
	{
		return NULL;
	}
	//1.每个对应字符比较
	while (*dist == *source)
	{
		//相等才会进来判断 如果目标字符串到\0 则source也是\0
		if (*dist == '\0')
			return 0;
		//++ 进行下个字符比较
		dist++;
		source++;
	}
	//比较大小 返回
	/*if (*dist > *source)
	{
		return 1;
	}
	else
	{
		return -1;
	}*/
	//return *dist > *source ? 1 : -1;
	return dist - source;
}
int my_strncmp(const char* dist,const char* source,size_t num)
{
	assert(dist && source);
	//判断是否有字符比较
	if (!num)
	{
		return 0;
	}
	//条件比较字符个数--  
	// 目标字符为\0 
	// 结合性从左到右
	while (--num && *dist &&(*dist == *source))
	{
		dist++;
		source++;
	}
	return *dist - *source;
}


字符串求包含字串函数 strstr

char* my_strstr(const char* dist, const char* source)
{
	assert(dist && source);
	const char* s1 = NULL;
	const char* s2 = NULL;
	// 记录起始位置
	const char* p = dist;

	//要查找的字符串为\0 空 返回dist
	if (!*source)
	{
		return (char*)dist;
	}
	while (*p != '\0')
	{
		// 回到起始位置
		s1 = p;
		s2 = source;
		//相等继续往后走 判断
		//前提 s1已经找完 大于等于s2
		//s2找完 s1不包含字串
		while (*s1 && *s2 && (*s1 == *s2))
		{
			s1++;
			s2++;
		}
		//判断s2是否已经判断完了
		if (*s2 == '\0')
		{
			return (char*)s2;
		}
		//如果不相等 往后加1
		p++;
	}
	return NULL;
}

标签:dist,++,C语言,char,source,字符串,return,模拟,const
From: https://www.cnblogs.com/worker618/p/16853072.html

相关文章

  • 四舍六入五成双(C语言版)
    四舍五入的小细节计算机的四舍五入与我们数学学的还是有点区别,下面开始讲解吧四舍五入的规则:如果需要约位的数<=4,舍去不进位如果需要约位的数>=6,舍6进1如果需要约......
  • C语言 旋转字符串
    C语言旋转字符串思路:1.循环需要旋转几次2.保存处于第一个的字符3.再将后面的所有字符往前挪动一位4.再把处于第一位的字符放在末尾//字符串旋转第一种解法......
  • C语言中出现[Error] assignment to expression with array type
    1.原因数组不能直接给数组赋值指针不能直接给数组赋值2.解决办法chara[]={'h','e','l','l','o'};charb[5];char*p=NULL;//错误情况charc[5]=a;//......
  • 实验3 C语言控制语句应用编程
    #include<stdio.h>#include<stdlib.h>#include<time.h>#include<windows.h>#defineN80voidprint_text(intline,intcol,chartext[]);voidprint_spaces......
  • 代码随想录算法训练营第八天|344、反转字符串|541、反转字符串Ⅱ|剑指Offer 05、替换
    344、反转字符串·两两交换给字符串翻个面doge题目链接:https://leetcode.cn/problems/reverse-string/submissions/思路:首尾交换代码实现:     时间复杂度O(n......
  • C语言学习之写出四位数的各位的数值
    以下为今天学习到的程序的的部分函数解释。(过程参考了本平台博客好友“碟”的《C语言学习记录2(分别计算一个三位数的各位)》的程序)#include<stdio.h>     //此为声......
  • ABAP-字符串语法综合运用
    *&---------------------------------------------------------------------**&ReportZ10*&*&-----------------------------------------------------------------......
  • 学习C语言的第3天
    //dengfenfaintmain(){ chararr[]={0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20}; inti; intsz=sizeof(arr)/sizeof(arr[0]); intk=14; intleft=0;......
  • C# .Net 以换行符(\r\n)分割字符串
    字符串数字的形式:1string[]StringsContent=strT.Split(newstring[]{"\r\n"},StringSplitOptions.None);2StringsContent=StringsContent.Where(s=>!string......
  • sql 查询结果拼接字符串
    --对查询出来的varchar类型数据,加引号和逗号,可用于在别的数据库进行in()操作--sqlserver拼接语句SELECT'''',productName,''','FROMproduct--mysql拼接语句SEL......