c++ 實現快速排序與二分查找 源代碼

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

 以下的代碼都是我經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;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章