本文实例讲述了C#自定义字符串替换Replace方法。分享给大家供大家参考。具体实现方法如下:
一、问题:
前一阵遇到一个如标题的算法题,是将原有字符串的某些片段替换成指定的新字符串片段,例如将源字符串: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 = 0; i < originalCharArray.Count(); i++) { if (originalCharArray[i] == strToBeCharArray[0]) { bool IsReplace = false; for (int j = 0; 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() - 1; for (int k = 0; 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 = 0; // 仅用于标记,辅助记录多少次 bool flag = true; // n:source字符串遍历的数值;j:find字符串遍历的数值 int n = 0, j = 0; // s:查找到字符串的开始索引,e:查找到字符串的结束索引 int s = 0, e = 0;
while (true) { // 判断字符是否相等 if (source[n] == find[j]) { // Source 序列+1 n++; // 判断是否为第一位相匹配 if (j == 0) { // 赋值给s,查找到头的索引 s = n; } // 查找到后下一次比较find的下一位 j++; // 标记暂时找到前面相同的字符 flag = true; } else { // 记录不完全匹配 flag = false; // find的索引归零 j = 0; // Source的索引继续想加 n++; }
// 已经查找完毕 if (j == find.Length) { // 完全匹配 if (flag) { // 查找的字符数量+1 findCount++; } // 记录查找的数组结尾索引 e = n; // source 索引继续+1 n++; // find的索引归零 j = 0; // 计算生成新字符串,之后继续循环,直到替换所有字符串 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 = 0; i < startIndex - 1; i++) { newStringArray[i] = source[i]; } // 当前临时开始索引 int tempCurrentStartLength = startIndex - 1; // 将需要替换的赋值给新的字符数组 for (int i = tempCurrentStartLength; i < tempCurrentStartLength + replace.Length; i++) { newStringArray[i] = replace[i - tempCurrentStartLength]; } // 将之后剩余的字符赋值给新的数组 for (int i = endIndex + 1; i < newArrayLength; i++) { newStringArray[i] = source[i - 1]; } // 返回转换后的字符串 return string.Concat(newStringArray); } }
希望本文所述对大家的C#程序设计有所帮助。
replace实用工具可以及时更改文件或标准输入中的字符串。它首先使用有限状态机来匹配长的字符串。该工具可以用来交换字符串。例如,下面的命令交换给定文件file1和file2中的a和b: shell> replace a b b a -- file1 file2 ... 使用--选项来指示字符串-替换列表的结束位置和开始的文件名。 在命令行中的任何文件名被及时修改,因此在转换之前,可能要对源文件进
本文向大家介绍JavaScript使用replace函数替换字符串的方法,包括了JavaScript使用replace函数替换字符串的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JavaScript使用replace函数替换字符串的方法。分享给大家供大家参考。具体如下: JavaScript通过replace函数替换字符串,下面的代码将Visit Microsoft中的MicroS
问题内容: 我有一个以字符串形式传递的句子,我正在对单词“ and”进行替换,我想用“”替换它。而且它不是用空格替换“和”一词。以下是我的逻辑示例。而当我调试此逻辑时,逻辑确实落入了句子。 这里有我想念的东西吗? 问题答案: 而当我调试此逻辑时,逻辑确实落入了句子。 是的,然后你放弃返回值。 Java中的字符串是不可变的-当你调用时,它不会更改现有字符串的内容-它会返回经过修改的新字符串。所以你要
我有一个作为字符串传入的句子,我正在对单词“and”进行替换,我想用“”替换它。它并没有用空白代替“和”。下面是我的逻辑示例。当我调试这个的时候,逻辑就落在句子里了。代替 这里有我遗漏的东西吗。
本文向大家介绍Java字符串替换函数replace()用法解析,包括了Java字符串替换函数replace()用法解析的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了Java字符串替换函数replace()用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 replace(char oldChar, char newChar)返回
本文向大家介绍C++中string替换所有指定字符串的方法,包括了C++中string替换所有指定字符串的方法的使用技巧和注意事项,需要的朋友参考一下 C++的string提供了replace方法来实现字符串的替换,但是对于将字符串中某个字符串全部替换这个功能,string并没有实现,我们今天来做的就是这件事。 首先明白一个概念,即string替换所有字符串,将”12212″这个字符串的所有”12