笔试题:04年_字符串替换

这是一个C语言实现的字符串替换函数,用于在字符串`s1`中将所有出现的`s2`替换为`s3`,同时保持原字符串不变。文章介绍了函数的思路、可能出现的问题(如内存溢出)以及解决方案。在main函数中,展示了如何使用这个函数处理用户输入的字符串。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

//程序由:HyperHorse整理,如有错误,请指出,谢谢
//编写一段函数,满足以下要求:将字符串s1中出现的所有s2替换为s3,并且不损坏字符串
//思路:1寻找子串的起始位置,2字符串移出足够空间,3替换字符串
//函数bug:若str长度较小,在进行多替换少时,可能内存溢出

char* replaceStr(char* str,char* strSub,char* strRep)
{
	if(NULL == str || NULL == strSub || NULL == strRep)//判空
	{
		printf("您给定的字符串为空,麻烦您再检查一下呗!");
		return NULL;
	}
	int iSubLen = strlen(strSub);
	int iRepLen = strlen(strRep);
	int iDiffLen = iSubLen - iRepLen;
	int i = 0;
	while('\0' != str[i])
	{
		int iBegin = i;//记录初始位置
		int iEnd = i;//记录结束位置
		int j = 0;

		//寻找子串在原始字符串中的起始位置
		while('\0' != strSub[j])
		{
			if(str[iEnd] == strSub[j])
			{
				iEnd++;
				j++;
			}
			else
			{
				break;
			}
		}

		//进行字符串的移位操作
		if('\0' == strSub[j] )//表明找到了子串
		{
			if(iDiffLen >=0 )//表明子串的长度>=替换字符串的长度时,需要将原始字符串中从iEnd处向前移动iDiffLen长度
			{
				for(int k = iEnd ; k < strlen(str) ; k++)//从前
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值