C#统计子字符串出现次数(转帖,http://www.it130.cn/)
C#中沒有統(tǒng)計(jì)子字符串出現(xiàn)次數(shù)的函數(shù),那么如何在C#求出字符串中某字符的出現(xiàn)次數(shù),比如求“ADSFGEHERGASDF”中“A”出現(xiàn)的次數(shù)。首先想到的方法當(dāng)然是從頭遍歷字符串并統(tǒng)計(jì):
c1 = 0;
for (int i = 0; i < str.Length; i++)
{
??? if (str[i] == 'A')
??? {
??????? c1++;
??? }
}
第二種方法也很容易想到,將字符串中所有要查找的字符去除,然后比較去除前后的字符串長度即可。這種方法遭到了某人的鄙視,據(jù)說性能很差而且多占空間。
c2 = str.Length - str.Replace("A", String.Empty).Length;
接下來某人又提出了第三種方法,是用要查找的字符為分隔符,將原字符串分隔為多個子串,然后求子串的數(shù)目即可。在C#中這是一個寫起來很短的方法:
c3 = str.Split(new char[] { 'A' }).Length - 1;
我們從原理可以推斷出三者性能的順序,但究竟差距是多少呢,還是要動手試驗(yàn)一下。這是非常經(jīng)典的測試代碼:
string str = "SADTHDGSAFSDGTGHRDGSADFADDRHDFSGASDAA";
Stopwatch sw = new Stopwatch();
long t;
int c = 0;
GC.Collect();
Application.DoEvents();
sw.Start();
for (int i = 0; i < 100000; i++)
{
??? c = 三種算法
}
sw.Stop();
t = sw.ElapsedMilliseconds;
首先我們確保正確性,經(jīng)測試三種方法都能正確處理多種情況,包括首尾、連續(xù)出現(xiàn)、不出現(xiàn)或串長度為0等,我所取的字符串是一個很普通的串。編譯為Release版,預(yù)運(yùn)行10次后獲得以下結(jié)果:
遍歷統(tǒng)計(jì):13毫秒
替換后比較長度:112毫秒
斷開字符串后計(jì)數(shù):233毫秒
這里已經(jīng)體現(xiàn)出差異,遍歷統(tǒng)計(jì)比替換后比較要快10倍,斷開字符串又要慢一些。接下來我又做了如下兩個測試:
1、不改變字符串的長度,增加或減少要查找字符串的個數(shù)。
2、不改變要查找字符出現(xiàn)的頻率,但增長字符串的長度。
結(jié)果發(fā)現(xiàn),三種方法都隨字符串長度增加線性變慢,而后兩種方法還隨要查找的字符增加而變慢。斷開字符串的方法還受要查找字符串分布情況的影響。
轉(zhuǎn)載于:https://www.cnblogs.com/hownet/archive/2007/11/15/960708.html
總結(jié)
以上是生活随笔為你收集整理的C#统计子字符串出现次数(转帖,http://www.it130.cn/)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: sql 2005学习笔记1
- 下一篇: 要你学刀,你偏学剑