




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、C#自定义字符串替换Replace方法实例本文实例讲述了C#自定义字符串替换Replace方法。分享给大家供大家参考。具体实现方法如下:一、问题:前一阵遇到一个如标题的算法题,是将原有字符串的某些片段替换成指定的新字符串片段,例如将源字符串:abcdeabcdfbcdefg中的cde替换成12345,得到结果字符串:ab12345abcdfb12345fg,即:abcdeabcdfbcdefg -> ab12345abcdfb12345fg。二、实现方法:显然不能用string.Replace方法,需要自定义一个方法 string Replace(string originalStrin
2、g, string strToBeReplaced, string strToReplace),下面是我的实现代码,在半个小时内完成,通过了调试和常规数据的测试验证,还算是及格吧。复制代码 代码如下:public static string Replace(string originalString, string strToBeReplaced, string strToReplace)string resultString = null;char originalCharArray = originalString.ToCharArray();char strToBeCharArray =
3、 strToBeReplaced.ToCharArray();char strToCharArray = strToReplace.ToCharArray();List<Char> newCharList = new List<Char>();for (int i = 0; i < originalCharArray.Count(); i+)if (originalCharArrayi = strToBeCharArray0)bool IsReplace = false;for (int j = 0; j < strToBeCharArray.Count()
4、; j+)if (i + j) < originalCharArray.Count()&& (originalCharArrayi + j = strToBeCharArrayj)IsReplace = true;elseIsReplace = false;break;if (IsReplace)i += strToBeCharArray.Count() - 1;for (int k = 0; k < strToCharArray.Count(); k+)newCharList.Add(strToCharArrayk);elsenewCharList.Add(ori
5、ginalCharArrayi);elsenewCharList.Add(originalCharArrayi);resultString = string.Join("", newCharList);return resultString;因为有时间限制的要求,我没有添加注释,不过代码量不算多,逻辑也算简单清晰,没有注释也OK啦,缺点是算法复杂度比较高。下面经过本人同意,转载一下同事Hello Kitty同学对同一问题的实现代码, 也换一种思路来解决同一个问题。代码稍多,也添加了一些附加功能,各种注释也很完备,当然也需要花费更多时间。欢迎大家有兴趣一同讨论此话题! PS:
6、就在刚才还发现了下面代码的一个bug,就当是隐藏彩蛋了!复制代码 代码如下:public class Replace/ <summary>/ Replace 方法/ </summary>/ <param name="source">原字符串</param>/ <param name="find">需要查找的字符串</param>/ <param name="replace">替换的字符串</param>/ <returns>最终
7、替换成功的字符串</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:查找到字符串的
8、结束索引int s = 0, e = 0;while (true)/ 判断字符是否相等if (sourcen = findj)/ Source 序列+1n+;/ 判断是否为第一位相匹配if (j = 0)/ 赋值给s,查找到头的索引s = n;/ 查找到后下一次比较find的下一位j+;/ 标记暂时找到前面相同的字符flag = true;else/ 记录不完全匹配flag = false;/ find的索引归零j = 0;/ Source的索引继续想加n+;/ 已经查找完毕if (j = find.Length)/ 完全匹配if (flag)/ 查找的字符数量+1findCount+;/ 记
9、录查找的数组结尾索引e = n;/ source 索引继续+1n+;/ find的索引归零j = 0;/ 计算生成新字符串,之后继续循环,直到替换所有字符串source = GetNewString(source, find, replace, s, e);/ Source遍历完毕,则退出循环if (n >= source.Length)break;/ 最终字符串return source;/ <summary>/ 获得新的字符串/ </summary>/ <param name="source">源字符串</param>
10、;/ <param name="find">需要查找的字符</param>/ <param name="replace">需要替换的字符</param>/ <param name="startIndex">查找到的字符开始索引</param>/ <param name="endIndex">查找到的字符结束索引</param>/ <returns>返回替换后的字符串</returns>public
11、 string GetNewString(string source, string find, string replace, int startIndex, int endIndex)/ 新字符串的长度int newArrayLength = source.Length + endIndex - startIndex;/ 新字符数组char newStringArray = new charnewArrayLength;/ 将前半部分复制给新字符串for (int i = 0; i < startIndex - 1; i+)newStringArrayi = sourcei;/ 当前临时开始索引int tempCurrentStartLength = startIndex - 1;/ 将需要替换的赋值给新的字符数组for (int i = tempCurrentStartLength; i < tempCurrentStartLength + replace.Length; i+)newStringArrayi =
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025北京师范大学淮南实验学校教师招聘9人(安徽)模拟试卷及参考答案详解一套
- 2025年上半年临沂市公安机关招录警务辅助人员(72名)考前自测高频考点模拟试题及1套参考答案详解
- 2025年昆明市法院系统招聘真题
- 2024年江苏南京财经大学招聘真题
- 2025年德阳市事业单位公开考试招聘工作人员笔试模拟试卷附答案详解(模拟题)
- 2025桂林银行校园招聘考前自测高频考点模拟试题及答案详解(网校专用)
- 2025广东深圳大学文化产业研究院张振鹏教授博士后招聘1人考前自测高频考点模拟试题附答案详解(突破训练)
- 2025年《中国烟草》杂志社有限公司(中国烟草总公司传媒中心)招聘考前自测高频考点模拟试题完整答案详解
- 2025年4月西安图书馆就业见习人员招聘(15人)模拟试卷及1套完整答案详解
- 2025福建福州市罗源县城市管理和综合执法局协管员招聘4人模拟试卷附答案详解(典型题)
- 舟山海域赤潮发生特点及成因分析
- 湿陷性黄土湿陷量计算表
- 丝杠安全操作保养规定
- 体育测量与评价PPT课件-第九章 运动员选材的测量与评价
- 在课堂教学中寻找发展学生科学思维的生长点课件
- 《情满今生》读书笔记模板
- 胸痛中心网络医院STEMI患者绕行急诊和CCU方案流程图
- 大众蔚揽保养手册
- 急危重病人营养与代谢支持
- GB/T 7216-2009灰铸铁金相检验
- GB/T 5796.3-1986梯形螺纹基本尺寸
评论
0/150
提交评论