c语言找子串

该博客介绍了一个C语言程序,用于查找字符串中的子串并进行替换。程序使用了strstr()函数来寻找子串,并通过memcpy()和循环实现替换。在main函数中进行了测试,展示了如何使用这些字符串操作。

简单的额一道题,求字符串子串的个数,顺便复习一下几个常用函数

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

int ChangeStr( char *src,  char *substr, char *chg_str,
char *des, int *ncount)
{
//循环变量
int i=0,j=0;
//找到子串的次数
int count=0;
//指针变量
char *psrc= NULL;
//待搜索子串的长度
int len=strlen(substr);
//用来记录找到子串的位置
int a[100]={0}; 
//输出指针,由于src是常量指针,它所指向的内存中的内容不能改变,所以用des将内容
//拷贝出来
memcpy(des,src,strlen(src)*sizeof(char)+1);
psrc=strstr(src,substr);
assert(NULL!=src);
assert(NULL!=substr);
if (NULL==psrc)
{
//没有找到返回0
return 0;
}
while(psrc!=NULL)
{
a[count]=psrc-src;
count++;
psrc+=len;
psrc=strstr(psrc,substr);
}
//将子串substr换成chg_str
//这里这两个字符串长度相同
for(i=0; i<count; i++)
{
for(j=0; j<len; j++)
{
des[a[i]+j]=chg_str[j];
}
}
*ncount=count;

return 1;
}

//主调函数,测试
int main()
{
char *buf="abcd11111abcd2222abcdqqqqq";
char *subbuf="abcd";
char *sbu="dcba";
char des[40];
int count;
//这里传的count是指针
if (ChangeStr(buf,subbuf,sbu,des,&count))
{
printf("字符串:%s\n字符串:%s的个数:%d\n变换后的字符串:%s\n",
buf,subbuf,count,des);
}
return 0;
}

针对C语言的字符串操作函数

1:strcat()

2:strchr()与strstr()

3:strcpy()

4:字符串比较函数strcmp()

5:字符串分割,有点类似python中的split()函数

6:返回两个字符串中首个字符串的位置

7:将字符串转换为整数

 

常见的内存操作函数

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值