c++ 實現快速排序與二分尋找 原始碼

來源:互聯網
上載者:User

今天閑來無事,寫寫快速排序與二分尋找的代碼,也給自己回顧一篇。

 以下的代碼都是我經vc2005 測試通過的。

//劃分區間函數  最主要的函數
int Partitionfun(int * intarray,int i,int j)
{
 int key = intarray[i]; //排序的主元值
 while(i<j)
 {
  while(i<j&&intarray[j]>=key) j--;
  if (i<j)
  {
   intarray[i]= intarray[j];
   i++;
  }
  while(i<j&&intarray[i]<=key) i++;
  if (i<j)
  {
   intarray[j] = intarray[i];
   j--;
  }
 }
 intarray[i]= key;
 return i;
}

//遞迴調用上面的函數
void   QuickSort(int * intarray,int i,int j)
{
  int midpos;
  if (i<j)
  {
    midpos= Partitionfun(intarray,i,j);
    QuickSort(intarray,i,midpos-1);
    QuickSort(intarray,midpos+1,j);
  }
}

 

//二分尋找

二分尋找又稱折半尋找,優點是比較次數少,尋找速度快,平均效能好;其缺點是要求待查表為有序表。首先,假設表中元素是按升序排列,將表中間位置記錄的關鍵字與尋找關鍵字比較,如果兩者相等,則尋找成功;否則利用中間位置記錄將表分成前、後兩個子表,如果中間位置記錄的關鍵字大於尋找關鍵字,則進一步尋找前一子表,否則進一步尋找後一子表。重複以上過程,直到找到滿足條件的記錄,使尋找成功,或直到子表不存在為止,此時尋找不成功。

int  BinarySearch(int * pArray,int pKey,int pStart,int pEnd)
{
 int midd;
 while(pStart<=pEnd)    // 注意事項 別寫成了小於了,這樣查詢最後的元素有問題
 {
  midd=(pStart+pEnd)/2;
  if (pArray[midd]==pKey)
  {
   return midd;
  }else if(pArray[midd]>pKey)
  {
   pEnd = midd-1;   //記得-1(不然死迴圈)
  }else
  {
   pStart= midd+1;  //記得+1  (不然死迴圈)
  }

 }
   return  midd;

}

 

//尋找數組第2大值

int FindSecond(int * pArray,int len)
{
 int sencond = 0;
 int maxValue = pArray[0];

 for(int i=1;i<len;i++)
 {
  if (maxValue<pArray[i])
  {
   sencond = maxValue;
   maxValue=pArray[i];
  }else if (pArray[i]>sencond)
  {
   sencond = pArray[i];
  }
 }

 return sencond;
}

 

程式調用
void main()
{
 cout<<"hello word!"<<endl;
 int  intarray[]={12,52,36,22,11,44,5,22,336,2,25,3,6,25,1,4,8,5,4,11,44,55,66,33,22,44,77,55,22,11,44,55,66,5,5555,22222,11111,777777,444444,11111,111,
 5555,5555,66666,333333,22222,11111,44444,77777,454444,555555,444444111,1111144,1144};

 QuickSort(intarray,0,sizeof(intarray)/sizeof(int)-1);

 for (int i=0;i<sizeof(intarray)/sizeof(int);i++)
 {
  cout<<intarray[i]<<endl;
 }

 
 cout<<BinarySearch(intarray,444444111,0,sizeof(intarray)/sizeof(int)-1)<<endl;
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.