本篇內容主要講解“Java中怎么實現快速排序+歸并排序”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Java中怎么實現快速排序+歸并排序”吧!
package com.cjw.sort;
import lombok.extern.slf4j.Slf4j;
/**
* 簡單快速排序
* @author wucj
* @date 2019-06-30 22:15
**/
@Slf4j
public class QuickSortDemo {
/**
* 快速排序
* @param arr 數組
* @param start 開始
* @param end 結束
*/
public void quickSort(int[] arr,int start,int end){
if(start<end){
int i=start;
int value = arr[start];
for(int j=start+1;j<=end;j++){
if(arr[j]<value){
int temp = arr[j];
arr[j] = arr[i+1];
arr[i+1] = temp;
i++;
}
}
arr[start] = arr[i];
arr[i] = value;
quickSort(arr,start,i-1);
quickSort(arr,i+1,end);
}
}
}
package com.cjw.sort;
/**
* 簡單歸并排序
* @author wucj
* @date 2019-06-30 23:06
**/
public class MergeSortDemo {
public void sort(int[] arr,int low,int high){
int mid = (high+low)/2;
if(low<high){
sort(arr,low,mid);
sort(arr,mid+1,high);
merge(arr,low,mid,high);
}
}
private void merge(int[] arr,int low,int mid,int high){
int[] tempArr = new int[high-low+1];
int i=low;
int j=mid+1;
int k =0;
while (i<=mid&&j<=high){
if(arr[i]<arr[j]){
tempArr[k++]=arr[i++];
}else{
tempArr[k++] = arr[j++];
}
}
while (i<=mid){
tempArr[k++] = arr[i++];
}
while (j<=high){
tempArr[k++]=arr[j++];
}
for(int n=0;n<tempArr.length;n++){
arr[n+low] = tempArr[n];
}
}
}
單元測試:
package com.cjw.concurrent;
import com.cjw.sort.MergeSortDemo;
import com.cjw.sort.QuickSortDemo;
import lombok.extern.slf4j.Slf4j;
import org.junit.Test;
import java.util.Arrays;
/**
* @author wucj
* @date 2019-06-30 22:24
**/
@Slf4j
public class SortTest {
private int[] arr1 = {11,213,134,44,77,78,23,43};
@Test
public void quickSortTest(){
int[] arr11 = Arrays.copyOf(arr1,arr1.length);
QuickSortDemo quickSortDemo = new QuickSortDemo();
quickSortDemo.quickSort(arr11,0,arr11.length-1);
soutArr(arr1);
soutArr(arr11);
}
@Test
public void mergeSortTest(){
int[] arr11 = Arrays.copyOf(arr1,arr1.length);
MergeSortDemo mergeSortDemo = new MergeSortDemo();
mergeSortDemo.sort(arr11,0,arr11.length-1);
soutArr(arr1);
soutArr(arr11);
}
private void soutArr(int[] tempArr){
StringBuffer s = new StringBuffer();
for (int i=0;i<tempArr.length;i++) {
s.append(tempArr[i]);
if(i<(tempArr.length-1)){
s.append("->");
}
}
log.info("數組排序結果:{}",s);
}
}到此,相信大家對“Java中怎么實現快速排序+歸并排序”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。