【C语言】字符串库函数

strstr函数 实现
/*
strstr 用滚动比较的方法来实现 
*/
#include <stdio.h>
int main()
{
	
	char* mystrstr(const char* str1, const char* str2);
	char a[101], b[101];
	scanf("%s%s", &a, &b);
	printf("%s", mystrstr(a, b));
	
}
char* mystrstr(const char* str1, const char* str2) {
	char* p1 = str1;
	char* p2 = str2;
	int i = 0;
	while (*p1)//*检测到回车'\n'的时候跳出循环)
	{
		char* flag = p1;//设置标志位,方便回滚。
		while (*p1 == *p2 && *p1 != '\0') {
  //结束循环的条件有两种:1 ,字符不相等,不是子串 ; 2 ,p2到底了都是相等的, 子串 
			p1++;
			p2++;
		}

		if (p2=='\0') //第二个字符串走到\n了吗????
 		{
			return flag;
			i++;//返回找到子串的起始位置。
		}
		if (!*p1)
		{
			//走到这里,p1到达\0 而p2没有到达\0,没有找到
			return NULL;
		}
		//走到这里,没有匹配成功,继续从下一位开始匹配整个子串
		p1++;
		
	}
	return NULL;
}




接字符串
#include <stdio.h>
void mystrcpy(char str[], char str2[]);
int main()
{
	char str1[100], str2[200];
	gets(str1);
	gets(str2);
	f(str1, str2); //传数组名即可不用str[100]!!!
	printf("%s", str1);//打印str的地址的内容就可以,不用返回!!!
}
void mystrcpy(char str[], char str2[])
{
	int i = 0,a=0;
	while (str[i] != '\0')
	{
		i++;
		a = i;
	}
	for (i = 0; str2[i] != 0; i++)
	{
		str[a++] = str2[i];
	}
	str[a] = '\0';//记得给他补回回车
}

strcpy
原型:char *strcpy(char *dst ,char const *src) ;
注意: 因为dst参数将被修改,所以它必须是一个字符数组或者指向动态分配内存的数组的指针 ,不能是字符串常量 。

程序员必须保证目标字符数组的空间足以容纳需要复制的字符串 , 如果字符串比数组要大,依然可以被复制 , 那么数组后面的内存空间就会被覆盖。 (这样对程序来说不是件好事。) ---------------来源于《c与指针》

返回值: 返回第一个参数的一份拷贝,就是一个指向目标字符数组的指针。(大多情况下返回值都被忽略了)

strcat (char *dst ,char const *src) ;
连接字符串,将一个字符串连接到另一个字符串的后面 ;

strcmp
原型:int strcmp (char const *s1 ,char const *s2);

比较两个字符串: s1>s2 返回一个整数
s2>s1 返回一个负数
s2=s1 返回0

strstr 函数: 返回一个s2 第一次出现的位置

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值