国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

C#自定義字符串替換Replace方法

2019-11-17 02:45:56
字體:
供稿:網(wǎng)友

C#自定義字符串替換Replace方法

前一陣遇到一個(gè)如標(biāo)題的算法題,是將原有字符串的某些片段替換成指定的新字符串片段,例如將源字符串:abcdeabcdfbcdefg中的cde替換成12345,得到結(jié)果字符串:ab12345abcdfb12345fg,即:abcdeabcdfbcdefg -> ab12345abcdfb12345fg。

顯然不能用string.Replace方法,需要自定義一個(gè)方法 string Replace(string originalString, string strToBeReplaced, string strToReplace),下面是我的實(shí)現(xiàn)代碼,在半個(gè)小時(shí)內(nèi)完成,通過了調(diào)試和常規(guī)數(shù)據(jù)的測(cè)試驗(yàn)證,還算是及格吧。

 1 public static string Replace(string originalString, string strToBeReplaced, string strToReplace) 2         { 3             string resultString = null; 4             char[] originalCharArray = originalString.ToCharArray(); 5             char[] strToBeCharArray = strToBeReplaced.ToCharArray(); 6             char[] strToCharArray = strToReplace.ToCharArray(); 7             List<Char> newCharList = new List<Char>(); 8  9             for (int i = 0; i < originalCharArray.Count(); i++)10             {11                 if (originalCharArray[i] == strToBeCharArray[0])12                 {13                     bool IsReplace = false;14                     for (int j = 0; j < strToBeCharArray.Count(); j++)15                     {16                         if (((i + j) < originalCharArray.Count())17                             && (originalCharArray[i + j] == strToBeCharArray[j]))18                         {19                             IsReplace = true;20                         }21                         else22                         {23                             IsReplace = false;24                             break;25                         }26                     }27                     if (IsReplace)28                     {29                         i += strToBeCharArray.Count() - 1;30                         for (int k = 0; k < strToCharArray.Count(); k++)31                         {32                             newCharList.Add(strToCharArray[k]);33                         }34                     }35                     else36                     {37                         newCharList.Add(originalCharArray[i]);38                     }39                 }40                 else41                 {42                     newCharList.Add(originalCharArray[i]);43                 }44             }45 46             resultString = string.Join("", newCharList);47             return resultString;48         }

因?yàn)橛袝r(shí)間限制的要求,我沒有添加注釋,不過代碼量不算多,邏輯也算簡(jiǎn)單清晰,沒有注釋也OK啦,缺點(diǎn)是算法復(fù)雜度比較高。下面經(jīng)過本人同意,轉(zhuǎn)載一下同事Hello Kitty同學(xué)對(duì)同一問題的實(shí)現(xiàn)代碼,也換一種思路來解決同一個(gè)問題。代碼稍多,也添加了一些附加功能,各種注釋也很完備,當(dāng)然也需要花費(fèi)更多時(shí)間。歡迎博友們有興趣一同討論此話題,請(qǐng)自由留言加以評(píng)論!PS:就在剛才還發(fā)現(xiàn)了下面代碼的一個(gè)bug,就當(dāng)是隱藏彩蛋了!

  1 public class Replace  2     {  3         /// <summary>  4         /// Replace 方法  5         /// </summary>  6         /// <param name="source">原字符串</param>  7         /// <param name="find">需要查找的字符串</param>  8         /// <param name="replace">替換的字符串</param>  9         /// <returns>最終替換成功的字符串</returns> 10         public string Replace(string source, string find, string replace) 11         { 12             // 要查找的字符串大于原來字符串,則不處理,返回原來字符 13             if (find.Length > source.Length) 14             { 15                 return source; 16             } 17  18             // 記錄找到多少次 19             int findCount = 0; 20             // 僅用于標(biāo)記,輔助記錄多少次 21             bool flag = true; 22             // n:source字符串遍歷的數(shù)值;j:find字符串遍歷的數(shù)值 23             int n = 0, j = 0; 24             // s:查找到字符串的開始索引,e:查找到字符串的結(jié)束索引 25             int s = 0, e = 0; 26  27             while (true) 28             { 29                 // 判斷字符是否相等 30                 if (source[n] == find[j]) 31                 { 32                     // Source 序列+1 33                     n++; 34                     // 判斷是否為第一位相匹配 35                     if (j == 0) 36                     { 37                         // 賦值給s,查找到頭的索引 38                         s = n; 39                     } 40                     // 查找到后下一次比較find的下一位 41                     j++; 42                     // 標(biāo)記暫時(shí)找到前面相同的字符 43                     flag = true; 44                 } 45                 else 46                 { 47                     // 記錄不完全匹配 48                     flag = false; 49                     // find的索引歸零 50                     j = 0; 51                     // Source的索引繼續(xù)想加 52                     n++; 53                 } 54  55                 // 已經(jīng)查找完畢 56                 if (j == find.Length) 57                 { 58                     // 完全匹配 59                     if (flag) 60                     { 61                         // 查找的字符數(shù)量+1 62                         findCount++; 63                     } 64                     // 記錄查找的數(shù)組結(jié)尾索引 65                     e = n; 66                     // source 索引繼續(xù)+1 67                     n++; 68                     // find的索引歸零 69                     j = 0; 70                     // 計(jì)算生成新字符串,之后繼續(xù)循環(huán),直到替換所有字符串 71                     source = GetNewString(source, find, replace, s, e); 72                 } 73                 // Source遍歷完畢,則退出循環(huán) 74                 if (n >= source.Length) 75                 { 76                     break; 77                 } 78             } 79             // 最終字符串 80             return source; 81         } 82  83         /// <summary> 84         /// 獲得新的字符串 85         /// </summary> 86         /// <param name="source">源字符串</param> 87         /// <param name="find">需要查找的字符</param> 88         /// <param name="replace">需要替換的字符</param> 89         /// <param name="startIndex">查找到的字符開始索引</param> 90         /// <param name="endIndex">查找到的字符結(jié)束索引</param> 91         /// <returns>返回替換后的字符串</returns> 92         public string GetNewString(string source, string find, string replace, int startIndex, int endIndex) 93         { 94             // 新字符串的長(zhǎng)度 95             int newArrayLength = source.Length + endIndex - startIndex; 96             // 新字符數(shù)組 97             char[] newStringArray = new char[newArrayLength]; 98             // 將前半部分復(fù)制給新字符串 99             for (int i = 0; i < startIndex - 1; i++)100             {101                 newStringArray[i] = source[i];102             }103             // 當(dāng)前臨時(shí)開始索引104             int tempCurrentStartLength = startIndex - 1;105             // 將需要替換的賦值給新的字符數(shù)組106             for (int i = tempCurrentStartLength; i < tempCurrentStartLength + replace.Length; i++)107             {108                 newStringArray[i] = replace[i - tempCurrentStartLength];109             }110             // 將之后剩余的字符賦值給新的數(shù)組111             for (int i = endIndex + 1; i < newArrayLength; i++)112             {113                 newStringArray[i] = source[i - 1];114             }115             // 返回轉(zhuǎn)換后的字符串116             return string.Concat(newStringArray);117         }118     }


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 镇雄县| 泰州市| 遵化市| 清镇市| 麦盖提县| 新丰县| 陕西省| 辽宁省| 子长县| 大田县| 琼结县| 永济市| 阳原县| 泸西县| 中西区| 玛纳斯县| 松潘县| 永德县| 交口县| 宁武县| 龙岩市| 宿州市| 柯坪县| 沙田区| 牡丹江市| 通化县| 石狮市| 灵璧县| 镇江市| 广饶县| 宜丰县| 保德县| 伊吾县| 新竹市| 前郭尔| 桑日县| 天峻县| 垣曲县| 海兴县| 乌兰察布市| 宾阳县|