C#自定义字符串替换Replace方法实例_C#教程-查字典教程网
C#自定义字符串替换Replace方法实例
C#自定义字符串替换Replace方法实例
发布时间:2016-12-28 来源:查字典编辑
摘要:本文实例讲述了C#自定义字符串替换Replace方法。分享给大家供大家参考。具体实现方法如下:一、问题:前一阵遇到一个如标题的算法题,是将原...

本文实例讲述了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#程序设计有所帮助。

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新C#教程学习
    热门C#教程学习
    编程开发子分类