今天閒來無事,寫寫快速排序與二分查找的代碼,也給自己回顧一篇。
以下的代碼都是我經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;
}