真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

C/C++中如何提高查找速度-創(chuàng)新互聯(lián)

這篇文章主要介紹了C/C++中如何提高查找速度,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比大武口網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式大武口網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋大武口地區(qū)。費(fèi)用合理售后完善,10多年實(shí)體公司更值得信賴。

示例:

//在一個(gè)int數(shù)組中查找某個(gè)元素
int find(int A[],int n,int element)
{
 for( int i = 0; i < n; i++ )
 {
  if( A[i] == element )
   return i;
 }
 return -1;
}

//在一個(gè)字符串中查找某個(gè)字符
int find(string& str,char c)
{ 
 for( int i = 0; i < str.length(); i++ )
 {
  if( str[i] == c )
   return i;
 }
 return -1;
}

雖然每次都是寫出這樣的代碼,但我總覺得for循環(huán)中的<判斷有點(diǎn)多余,比如數(shù)組中有100個(gè)元素,我們明明知道前99個(gè)是不會(huì)數(shù)組越界的,根本不需要判斷i

通過哨兵的方式去掉這多余的判斷,將上面兩個(gè)方法改造如下:

//在一個(gè)int數(shù)組中查找某個(gè)元素
int find1(int A[],int n,int element)
{
 if( n <= 0 )
  return -1;
 if( A[--n] == element )
  return n;

 int hold = A[n];
 A[n] = element;
 int i = 0;
 for( ; ; i++ ) 
 {
  if( A[i] == element )
   break;
 }
 A[n] = hold;
 return i < n ? i : -1; 
}

//在一個(gè)字符串中查找某個(gè)字符
int find1(string& str,char c)
{ 
 int n = str.length();
 if( n <= 0 )
  return -1;
 if( str[--n] == c )
  return n;
 int hold = str[n];
 str[n] = c;
 int i = 0;
 for( ; ; i++ ) 
 {
  if( str[i] == c )
   break;
 }
 str[n] = hold;
 return i < n ? i : -1; 
}

我勒個(gè)去,怎么變得這么長,但的確是減少了判斷的次數(shù),如果數(shù)組較大的話提高運(yùn)行速度肯定是一定的,如果你非要說數(shù)組很小的話,說不定速度還要降低呢,那你不這樣寫不就得了,好了廢話少說,雖然代碼已經(jīng)很簡(jiǎn)單明了了,但我還是簡(jiǎn)單說一下思路。

就是在數(shù)組的末尾加一個(gè)哨兵,即使不判斷i

先判斷最后一個(gè)元素的值是不是我們要查找的數(shù),如果是,返回其下標(biāo);如果不是,將最后一個(gè)數(shù)的值保存起來,將要查找的那個(gè)數(shù)賦給最后一個(gè)元素,循環(huán)查找指定的元素,不用判斷數(shù)組越界,if語句必然break,將最后一個(gè)元素的值還原,最后只用判斷i

最后在做一個(gè)簡(jiǎn)單的性能測(cè)試,看到底能否提高查找速度。

測(cè)試代碼如下:

void testFind()
{
 int N = 200000;
 int* A = new int[N];
 A[N-2] = 1; 

 DWORD start = ::GetTickCount64();
 for( int i = 0; i < 10000; i++ ) 
  find(A,N,1);
 DWORD end = ::GetTickCount64();
 cout <<"優(yōu)化前:" << end - start <<" 毫秒" << endl; 

 start = ::GetTickCount64(); 
 for( int i = 0; i < 10000; i++ ) 
  find1(A,N,1);
 end = ::GetTickCount64();
 cout <<"優(yōu)化后:" << end - start <<" 毫秒" << endl; 
}

運(yùn)行結(jié)果如下:

C/C++中如何提高查找速度

速度還是會(huì)快一點(diǎn)

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“C/C++中如何提高查找速度”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)建站,關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。


新聞標(biāo)題:C/C++中如何提高查找速度-創(chuàng)新互聯(lián)
URL分享:http://weahome.cn/article/pcehs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部