前一阵遇到一个如标题的算法题,是将原有字符串的某些片段替换成指定的新字符串片段,例如将源字符串: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. Mysql数据库启动

    1.改变数据库的访问ip: vim /etc/mysql/my.cnf 找到下面选项: bind-address            = 192.168.1.128 修改即可. 2.mysql启动命 ...

  2. NSDictionary所有API的学习。

    <欢迎大家增加iOS开发学习交流群:QQ529560119> @property (readonly)NSUInteger count; //1.利用指定的key寻找相应的value - ...

  3. swift锁屏播放,音乐进度更新,专辑,歌手名显示

    我自己用的音乐播放器是自带的AVPlayer 导入头文件#import <MediaPlayer/MediaPlayer.h> 远程控制事件接收与处理- (void)viewWillApp ...

  4. 查看oracle锁及解决办法

    SQL> select t2.username,t2.sid,t2.serial#,t2.logon_time from v$locked_object t1, v$session t2 whe ...

  5. asp:UpdatePanel中js失效问题已解决

    1.js function textSAll(o) { o.select(); } var dddd_dd = function () { $(":text").on(" ...

  6. 引言:Canvas绘图API快速入门

    引言:Canvas绘图API快速入门 在接触HTML5的初学者包括我都在很多地方见到非常炫的一些页面,甚至好多学习HTML5的开发者都是冲着Web端的页游去的,那么HTML5那么绚丽的页面效果以及游戏 ...

  7. TextField的所有属性和方法(转)

    转自:http://tsyouaschen.iteye.com/blog/600255 表一 TextField 对象的方法 方法 说明TextField.addListener 加入接收触发事件如文 ...

  8. Android 判断当前设备是否联网

    首先添加相关的权限: <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> ...

  9. FileProvider是个什么东西?

    FileProvider是个什么东西? 在<读取并监控文件的变化>中,我们通过三个简单的实例演示从编程的角度对文件系统做了初步的体验,接下来我们继续从设计的角度来继续认识它.这个抽象的文件 ...

  10. python---连接MySQL第五页

    Connector/Python Connection Arguments A connection with the MySQL server can be established using ei ...