前一阵遇到一个如标题的算法题,是将原有字符串的某些片段替换成指定的新字符串片段,例如将源字符串:abcdeabcdfbcdefg中的cde替换成12345,得到结果字符串:ab12345abcdfb12345fg,即:abcdeabcdfbcdefg -> ab12345abcdfb12345fg。

显然不能用string.Replace方法,需要自定义一个方法 string Replace(string originalString, string strToBeReplaced, string strToReplace),下面是我的实现代码,在半个小时内完成,通过了调试和常规数据的测试验证,还算是及格吧。

 public static string Replace(string originalString, string strToBeReplaced, string strToReplace)
{
string resultString = null;
char[] originalCharArray = originalString.ToCharArray();
char[] strToBeCharArray = strToBeReplaced.ToCharArray();
char[] strToCharArray = strToReplace.ToCharArray();
List<Char> newCharList = new List<Char>(); for (int i = ; i < originalCharArray.Count(); i++)
{
if (originalCharArray[i] == strToBeCharArray[])
{
bool IsReplace = false;
for (int j = ; j < strToBeCharArray.Count(); j++)
{
if (((i + j) < originalCharArray.Count())
&& (originalCharArray[i + j] == strToBeCharArray[j]))
{
IsReplace = true;
}
else
{
IsReplace = false;
break;
}
}
if (IsReplace)
{
i += strToBeCharArray.Count() - ;
for (int k = ; k < strToCharArray.Count(); k++)
{
newCharList.Add(strToCharArray[k]);
}
}
else
{
newCharList.Add(originalCharArray[i]);
}
}
else
{
newCharList.Add(originalCharArray[i]);
}
} resultString = string.Join("", newCharList);
return resultString;
}

因为有时间限制的要求,我没有添加注释,不过代码量不算多,逻辑也算简单清晰,没有注释也OK啦,缺点是算法复杂度比较高。下面经过本人同意,转载一下同事Hello Kitty同学对同一问题的实现代码, 也换一种思路来解决同一个问题。代码稍多,也添加了一些附加功能,各种注释也很完备,当然也需要花费更多时间。欢迎博友们有兴趣一同讨论此话题,请自由留言加以评论! PS:就在刚才还发现了下面代码的一个bug,就当是隐藏彩蛋了!

 public class Replace
{
/// <summary>
/// Replace 方法
/// </summary>
/// <param name="source">原字符串</param>
/// <param name="find">需要查找的字符串</param>
/// <param name="replace">替换的字符串</param>
/// <returns>最终替换成功的字符串</returns>
public string Replace(string source, string find, string replace)
{
// 要查找的字符串大于原来字符串,则不处理,返回原来字符
if (find.Length > source.Length)
{
return source;
} // 记录找到多少次
int findCount = ;
// 仅用于标记,辅助记录多少次
bool flag = true;
// n:source字符串遍历的数值;j:find字符串遍历的数值
int n = , j = ;
// s:查找到字符串的开始索引,e:查找到字符串的结束索引
int s = , e = ; while (true)
{
// 判断字符是否相等
if (source[n] == find[j])
{
// Source 序列+1
n++;
// 判断是否为第一位相匹配
if (j == )
{
// 赋值给s,查找到头的索引
s = n;
}
// 查找到后下一次比较find的下一位
j++;
// 标记暂时找到前面相同的字符
flag = true;
}
else
{
// 记录不完全匹配
flag = false;
// find的索引归零
j = ;
// Source的索引继续想加
n++;
} // 已经查找完毕
if (j == find.Length)
{
// 完全匹配
if (flag)
{
// 查找的字符数量+1
findCount++;
}
// 记录查找的数组结尾索引
e = n;
// source 索引继续+1
n++;
// find的索引归零
j = ;
// 计算生成新字符串,之后继续循环,直到替换所有字符串
source = GetNewString(source, find, replace, s, e);
}
// Source遍历完毕,则退出循环
if (n >= source.Length)
{
break;
}
}
// 最终字符串
return source;
} /// <summary>
/// 获得新的字符串
/// </summary>
/// <param name="source">源字符串</param>
/// <param name="find">需要查找的字符</param>
/// <param name="replace">需要替换的字符</param>
/// <param name="startIndex">查找到的字符开始索引</param>
/// <param name="endIndex">查找到的字符结束索引</param>
/// <returns>返回替换后的字符串</returns>
public string GetNewString(string source, string find, string replace, int startIndex, int endIndex)
{
// 新字符串的长度
int newArrayLength = source.Length + endIndex - startIndex;
// 新字符数组
char[] newStringArray = new char[newArrayLength];
// 将前半部分复制给新字符串
for (int i = ; i < startIndex - ; i++)
{
newStringArray[i] = source[i];
}
// 当前临时开始索引
int tempCurrentStartLength = startIndex - ;
// 将需要替换的赋值给新的字符数组
for (int i = tempCurrentStartLength; i < tempCurrentStartLength + replace.Length; i++)
{
newStringArray[i] = replace[i - tempCurrentStartLength];
}
// 将之后剩余的字符赋值给新的数组
for (int i = endIndex + ; i < newArrayLength; i++)
{
newStringArray[i] = source[i - ];
}
// 返回转换后的字符串
return string.Concat(newStringArray);
}
}

C#自定义字符串替换Replace方法的更多相关文章

  1. 字符串替换replace方法

    字符串替换replace方法: http://www.w3school.com.cn/jsref/jsref_replace.asp http://www.cnblogs.com/skywang/ar ...

  2. JQuery字符串替换replace方法

    在日常的js开发中,常常会用到JQuery, 当要把字符串中的内容替换时,如果使用类似C#的string.replace方法,如下 var str='aabbccaa'; str=str.replac ...

  3. JavaScript字符串替换replace方法

    在日常的js开发中, 当要把字符串中的内容替换时,如果使用类似C#的string.replace方法,如下 var str='aabbccaa'; str=str.replace('aa','dd') ...

  4. js中字符串的replace方法区分单双引号

    今天遇到一问题,js文件中调用字符串的replace方法,不起作用. 后来排查可能觉得replace("<option  value='1'>admin</option&g ...

  5. 浅谈JavaScript的字符串的replace方法

    JavaScript字符串提供了一个replace方法.replace方法可以接受两个参数:第一个参数可以使RegExp对象或者一个字符串,第二个参数可以是一个字符串或者一个函数.如果第一个参数是字符 ...

  6. string类自定义字符串替换函数replace

    #include <iostream> #include <string> using namespace std; /* *  函数功能:将string字符串中的某些字符替换 ...

  7. 字符串的replace()方法隐藏着什么不可告人秘密?

    最近在做JS算法项目时发现一个令我匪夷所思的问题, 这里想记录一下问题. 首先介绍一下字符串replace()方法的基本用法. replace() 方法使用一个替换值(replacement)替换掉一 ...

  8. Python3字符串替换replace(),translate(),re.sub()

    Python3的字符串替换,这里总结了三个函数,replace()和translate()和re.sub() replace() replace() 方法把字符串中的 old(旧字符串) 替换成 ne ...

  9. js 字符串的replace() 方法和实现replaceAll() 方法

    一.js中字符串的替换使用replace() 方法,但它只替换第一个匹配子串.如下例: <script type="text/javascript"> var sour ...

随机推荐

  1. Linux内核中常见内存分配函数(二)

    常用内存分配函数 __get_free_pages unsigned long __get_free_pages(gfp_t gfp_mask, unsigned int order) __get_f ...

  2. web api 文档声明

    namespaceHelloWebAPI.Controllers{     usingHelloWebAPI.Models;     usingSystem;     usingSystem.Coll ...

  3. 关于Console的Main(String[] args)参数输入

    之前接触一个往Console里输入参数的项目,资深QA教我怎么run,灰常脸红. 今日无事,baidu之. Step1 写简单Console Code. class Program { static ...

  4. 键盘事件之keydown keypress keyup区别

    经过测试,显然事件执行的顺序是: keydown->keypress->keyup. 但是连续按一个按键的话,会一直触发:keydown keypress.直到你提起按键,会触发keyup ...

  5. C# 几种退出程序的方式

    C# WinForm程序退出的方法 1.this.Close(); 只是关闭当前窗口,若不是主窗体的话,是无法退出程序的,另外若有托管线程(非主线程),也无法干净地退出: 2.Application. ...

  6. 在一个apk中调用另外一个apk中的activity

    今天忽然想到如果要在一个activity中调用另外一个activity该怎么办呢? 感觉这个应该比较简单,应为activity的启动方式就两种:显式启动.隐式启动: 显式启动的话肯定不行,那就只能使用 ...

  7. erp crm oa

    erp是企业管理计划 crm是客户关系管理 oa是办公自动化erp管理的是企业的进销存.产供销.财务等crm主要是管理企业的客户,可以和erp的销售系统挂钩oa主要是管理一些内部的文档.公告,行政信息 ...

  8. zoj1093 Monkey and Banana

    写到现在,发现1025,1076之前写的都是同一种题型:关于DAG的最长路(最短路). 首先要建立模型,根据关系,确定点和点之间的关系,构成一个DAG,前面几道题每个点之间距离默认为1,这一道题不同点 ...

  9. Java多线程并发编程之原子变量与非阻塞同步机制

    1.非阻塞算法 非阻塞算法属于并发算法,它们可以安全地派生它们的线程,不通过锁定派生,而是通过低级的原子性的硬件原生形式 -- 例如比较和交换.非阻塞算法的设计与实现极为困难,但是它们能够提供更好的吞 ...

  10. jQuery学习-事件之绑定事件(五)

    大家应该还记得dispatch方法中有这么一段代码: event = jQuery.event.fix( event ); event的修复是在fix这个方法中的,而在fix中是通过 new jQue ...