zoukankan      html  css  js  c++  java
  • 实现字符串的查找和替换 分类: c/c++ 2014-10-09 22:33 469人阅读 评论(0) 收藏

    在字符串中查找目标字符串并将其替换为指定字符串,返回替换的次数。接口为

    int find_str_replace(char *&str,const char *find_str,const char *replace_str)

    将str中所有find_str替换为replace_str。要求不利用STL,c实现代码如下:

    #include<stdio.h>
    #include<string.h>
    #include<stdlib.h>
    //查找str从fromwhere开始第一次出现sub_str的位置
    int find(const char *str,const char *sub_str,int fromwhere)
    {
    	int len=strlen(str);
    	int len_f=strlen(sub_str);
    	for(int i=fromwhere;i<len&&len-i>=len_f;i++)
    	{
    		int k=i;
    		int j=0;
    		while(j<len_f)
    		{
    			if(str[k]==sub_str[j])
    			{
    				k++;
    				j++;
    			}
    			else 
    			   break;
    		}
    		if(j==len_f)
    		{
    			return i;
    		}
    	}
    	return -1;
    }
    //替换fromwhere处的find_str为replace_str
    void replace(char *&str,const char *find_str,const char *replace_str,int fromwhere)
    {
    	int len=strlen(str);
    	int len_f=strlen(find_str);
    	int len_r=strlen(replace_str);
    	char *p=(char*)malloc(len+len_r-len_f);
    	memset(p,0,len+len_r-len_f);
    	strncpy(p,str,fromwhere);
    	strcat(p,replace_str);
    	strcat(p,str+fromwhere+len_f);
    	str=p;
    }
    //在str中将所有find_str替换为repalce_str;
    int find_str_replace(char *&str,const char *find_str,const char *replace_str)
    {
    	int num=0;
    	int len=strlen(str);
    	int len_r=strlen(replace_str);
    	int k=0;
    	while(k<len)
    	{
    		int pos=find(str,find_str,k);
    		if(pos==-1)break;
    		else
    		{
    			replace(str,find_str,replace_str,pos);
    			k=pos+len_r;
    			num++;
    		}
    	}
    	return num;
    }
    int main()
    {
    	char *a="123456783450987634243453";
    	char *b="345";
    	char *c="ABCD";
    	int num=find_str_replace(a,b,c);
    	printf("%s
    ",a);
    	printf("%d",num);
    	return 0;
    }
    若使用c++并利用STL,代码极其简单:

    #include<iostream>
    #include<string>
    using namespace std;
    int find_str_replace(string &str,string find_str,string replace_str)
    {
    	int num=0;
    	int len_f=find_str.length();
    	int len_r=replace_str.length();
    	int pos=str.find(find_str,0);
    	while(pos!=string::npos)
    	{
    	  str.replace(str.begin()+pos,str.begin()+pos+len_f,replace_str);
    	  pos=pos+len_r;
    	  pos=str.find(find_str,pos);
    	  num++;
    	}
    	return num;
    }
    int main()
    {
    	string a="123456783450987634243453";
    	string b="345";
    	string c="ABCD";
    	int num=find_str_replace(a,b,c);
    	printf("%s
    ",a.c_str());
    	printf("%d",num);
    	return 0;
    }



    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    We7 2.7版:全拖拽建站 开源CMS
    We7 CMS 2.6RC2版本发布 开源CMS
    LINQ简易教程
    C# 引用 C# DLL
    ASP.NET中母版页与JavaScript控制的一点小问题
    LINQ连接远端数据库问题
    ASP.NET中自动生成XML文件并通过XSLT显示在网页中的方法
    【转载】常见逻辑错误
    因为压力大变得很郁闷的时候怎么办
    代码覆盖度C#代码监控工具NCover、Rational PureCoverage、BullseyeCoverage
  • 原文地址:https://www.cnblogs.com/luo-peng/p/4646242.html
Copyright © 2011-2022 走看看