您好,登錄后才能下訂單哦!
#include <stdio.h>
void QuickSort(int * arr,int low,int high);
int findPost(int * arr,int low,int high);
void main(void){
int arr[7] = {-2, 1,-8, 0, -985, 4, -93};
QuickSort(arr,0,7);
for(int i = 0;i<7;i++){
printf("%d\n",arr[i]);
}
}
//快排算法
void QuickSort(int * arr,int low,int high){
int post;
if(low < high){
post = findPost(arr,low,high);
QuickSort(arr,low,post-1);
QuickSort(arr,post+1,high);
}
}
//查找節點位置
int findPost(int * arr,int low,int high){
int val = arr[low];
while(low < high){
while(arr[high] >= val && low < high){
high--;
}
arr[low] = arr[high];
while(arr[low] <= val && low <high){
low++;
}
arr[high] = arr[low];
}
arr[high] = val;
return high;
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。