思路:
public static void quickSort(int[] arr) {// int[] arr = {3,1,4,7,2,9,8};
doQuickSort(arr, 0, arr.length-1);
}
private static void doQuickSort(int[] arr, int left, int right) {if(left >= right) return;
int base = arr[left];
int i = left,j = right;
while (i< j) {while (arr[j] >= base && i< j) {j--;
}
while (arr[i]<= base && i< j) i++;
if(i< j) {int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
arr[left] = arr[i];
arr[i] = base;
doQuickSort(arr, left, i-1);
doQuickSort(arr, i+1, right);
}
歸并排序public static void divideSort(int[] arr, int left, int right) {if(left >= right)
return;
//取中間索引
int mid = (left + right)/2;
//分別排序
divideSort(arr,left,mid);
divideSort(arr,mid+1,right);
//合并結(jié)果
merge(arr,left,mid,right);
}
public static void merge(int[] arr,int left,int mid,int right) {int[] temp = new int[right-left+1];//建立臨時數(shù)組
int i = left;
int j = mid + 1;//指向兩個數(shù)組的起始位置
int k = 0;//指向臨時數(shù)組的起始位置
while(i<= mid && j<= right) {if(arr[i] >= arr[j]) {//將更小的arr[j]放進(jìn)臨時數(shù)組中
temp[k++] = arr[j++];
}else {//將更小的arr[i]放進(jìn)臨時數(shù)組中
temp[k++] = arr[i++];
}
}
while(i<= mid) {//前一個數(shù)組還有剩余
temp[k++] = arr[i++];
}
while(j<= right) {//前一個數(shù)組還有剩余
temp[k++] = arr[j++];
}
//將臨時數(shù)組中的值更新到原始數(shù)組中
for(int p = 0;p< temp.length;p ++) {arr[left+p] = temp[p];
}
}
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級服務(wù)器適合批量采購,新人活動首月15元起,快前往官網(wǎng)查看詳情吧
新聞名稱:排序算法java實(shí)現(xiàn)-創(chuàng)新互聯(lián)
文章路徑:http://aaarwkj.com/article14/pjpge.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、響應(yīng)式網(wǎng)站、標(biāo)簽優(yōu)化、微信小程序、小程序開發(fā)、營銷型網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容