ASP.NET從字符串中查找字符出現(xiàn)次數(shù)的具體實(shí)現(xiàn)方法
首先想到的方法當(dāng)然是從頭遍歷字符串并統(tǒng)計(jì):
c1=0;
for(inti=0;i {
if(str[i]=='A')
{
c1++;
}
}
第二種方法也很容易想到,將字符串中所有要查找的字符去除,然后比較去除前后的字符串長(zhǎng)度即可。這種方法遭到了某人的鄙視,據(jù)說性能很差而且多占空間。
c2=str.Length-str.Replace("A",String.Empty).Length;
接下來某人又提出了第三種方法,是用要查找的字符為分隔符,將原字符串分隔為多個(gè)子串,然后求子串的數(shù)目即可。在C#中這是一個(gè)寫起來很短的方法:
c3=str.Split(newchar[]{'A'}).Length-1;
我們從原理可以推斷出三者性能的順序,但究竟差距是多少呢,還是要?jiǎng)邮衷囼?yàn)一下。這是非常經(jīng)典的測(cè)試代碼:
stringstr="SADTHDGSAFSDGTGHRDGSADFADDRHDFSGASDAA";
Stopwatchsw=newStopwatch();
longt;
intc=0;
GC.Collect();
Application.DoEvents();
sw.Start();
for(inti=0;i<100000;i++)
{
c=三種算法
}
sw.Stop();
t=sw.ElapsedMilliseconds;
首先我們確保正確性,經(jīng)測(cè)試三種方法都能正確處理多種情況,包括首尾、連續(xù)出現(xiàn)、不出現(xiàn)或串長(zhǎng)度為0等,我所取的字符串是一個(gè)很普通的串。編譯為Release版,預(yù)運(yùn)行10次后獲得以下結(jié)果:
遍歷統(tǒng)計(jì):13毫秒
替換后比較長(zhǎng)度:112毫秒
斷開字符串后計(jì)數(shù):233毫秒
這里已經(jīng)體現(xiàn)出差異,遍歷統(tǒng)計(jì)比替換后比較要快10倍,斷開字符串又要慢一些。接下來我又做了如下兩個(gè)測(cè)試:
1、不改變字符串的長(zhǎng)度,增加或減少要查找字符串的個(gè)數(shù)。
2、不改變要查找字符出現(xiàn)的頻率,但增長(zhǎng)字符串的長(zhǎng)度。
結(jié)果發(fā)現(xiàn),三種方法都隨字符串長(zhǎng)度增加線性變慢,而后兩種方法還隨要查找的字符增加而變慢。
斷開字符串的方法還受要查找字符串分布情況的影響。
研究Replace函數(shù)和Split函數(shù)的實(shí)現(xiàn)可以徹底解決這個(gè)問題。不過我沒有心情細(xì)細(xì)研究了,我還是決定選用第二種方法——替換后比較長(zhǎng)度。雖然其速度比第一種方法慢,但易于改寫為求長(zhǎng)度不為1的子串出現(xiàn)次數(shù)的方法。第一種方法若改為求長(zhǎng)度大于1的字串就要考慮很多因素(盡管不一定真的很麻煩),我懶得想了,呵呵。
- 利用json獲取字符出現(xiàn)次數(shù)的代碼
- 統(tǒng)計(jì)jQuery中各字符串出現(xiàn)次數(shù)的工具
- 找出字符串中出現(xiàn)次數(shù)最多的字母和出現(xiàn)次數(shù)精簡(jiǎn)版
- JavaScript計(jì)算字符串中每個(gè)字符出現(xiàn)次數(shù)的小例子
- java字符串比較獲取字符串出現(xiàn)次數(shù)的示例
- php查找字符串出現(xiàn)次數(shù)的方法
- php獲取字符串中各個(gè)字符出現(xiàn)次數(shù)的方法
- JavaScript實(shí)現(xiàn)計(jì)算字符串中出現(xiàn)次數(shù)最多的字符和出現(xiàn)的次數(shù)
- python統(tǒng)計(jì)字符串中指定字符出現(xiàn)次數(shù)的方法
- C語言統(tǒng)計(jì)輸入字符各個(gè)字母出現(xiàn)頻率的解題思路
相關(guān)文章
Asp.Net模擬表單提交數(shù)據(jù)和上傳文件的實(shí)現(xiàn)代碼
這篇文章主要介紹了Asp.Net模擬表單提交數(shù)據(jù)和上傳文件的實(shí)現(xiàn)代碼,本文對(duì)3種情況都做了介紹,只有普通數(shù)據(jù)的表單、只上傳文件的表單、包含普通數(shù)據(jù)和上傳文件表單,需要的朋友可以參考下2014-08-08
jenkins部署.net平臺(tái)自動(dòng)化構(gòu)建的方法步驟
這篇文章主要介紹了jenkins部署.net平臺(tái)自動(dòng)化構(gòu)建的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-07-07
.NET發(fā)送郵件的實(shí)現(xiàn)方法示例
這篇文章主要給大家介紹了關(guān)于.NET發(fā)送郵件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用.net具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06
ASP.NET?Core獲取正確查詢字符串參數(shù)示例
這篇文章主要為大家介紹了ASP.NET?Core正確獲取查詢字符串參數(shù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
web.config中配置數(shù)據(jù)庫(kù)連接的方式
Web.config文件是一個(gè)XML文本文件,它用來儲(chǔ)存 ASP.NET Web 應(yīng)用程序的配置信息(如最常用的設(shè)置ASP.NET Web 應(yīng)用程序的身份驗(yàn)證方式),它可以出現(xiàn)在應(yīng)用程序的每一個(gè)目錄中。本文主要介紹web.config中配置數(shù)據(jù)庫(kù)連接的兩種方式,一起來看。2015-10-10
Hangfire在ASP.NET CORE中的簡(jiǎn)單實(shí)現(xiàn)方法
下面小編就為大家分享一篇Hangfire在ASP.NET CORE中的簡(jiǎn)單實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2017-11-11

