日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

三路归并排序

發布時間:2025/3/19 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 三路归并排序 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
三路歸并算法的關鍵在于分割點的下標計算 package fenzhi;public class MergeSortTest { public static void main(String[] args) { int[] data = new int[] { 5, 3, 6, 2, 16, 9, 4, 5, 3, 6, 2, 16, 9, 4, 7,10,11,15, 8,12,13,1,14,7,10,11,15, 8,12,13,1,14, 5, 3, 6, 2, 16, 9, 4, 7,10,11,15, 8,12,13,1,14}; print(data); mergeSort(data); System.out.println("排序后的數組:"); print(data); } public static void mergeSort(int[] data) { sort(data,0,data.length -1); } public static void sort(int[] data, int left, int right) { if (left >= right) return; // 找出中間索引 int center_first = left+((right-left)/3); int center_next=right-(right-left)/3;// 對左邊1/3數組進行遞歸 sort(data, left, center_first);// 對中間1/3數組進行遞歸 sort(data, center_first + 1, center_next);// 對右側1/3數組進行遞歸 sort(data,center_next+ 1, right);// 合并 merge(data, left, center_first,center_next, right);print(data); } public static void merge(int[] data, int left, int center_first,int center_next, int right) { // 臨時數組 int[] tmpArrList = new int[data.length]; // 三段數組的三個起點int first=left;int second = center_first+1; int third=center_next+1;//臨時數組的起點 int num=left;int tmp=left;while (first <= center_first && second<=center_next&&third <= right) { // 從三個數組中取出最小的放入臨時數組 if (data[first] <= data[second]&&data[first]<=data[third]) { tmpArrList[num] = data[first];first++;num++;} else if(data[second] <= data[first]&&data[second]<=data[third]){tmpArrList[num] = data[second];second++;num++;}else { tmpArrList[num] = data[third];third++;num++;} } // 當有一個數組率先全部排進臨時數組后,繼續排剩下的兩個數組while (first <= center_first&&second<=center_next) { if (data[first] <= data[second]) { tmpArrList[num] = data[first];first++;num++;} else{tmpArrList[num] = data[second];second++;num++;}} while (second <= center_next&&third<=right) { if (data[second] <= data[third]) { tmpArrList[num] = data[second];second++;num++;} else{tmpArrList[num] = data[third];third++;num++;}} while (first <= center_first&&third<=right) { if (data[first] <= data[third]) { tmpArrList[num] = data[first];first++;num++;} else{tmpArrList[num] = data[third];third++;num++;}} //當兩個數組全部排進臨時數組后,只剩下一個數組while (first <= center_first){tmpArrList[num] = data[first];first++;num++;}while (second <= center_next){tmpArrList[num] = data[second];second++;num++;}while(third<=right){tmpArrList[num] = data[third];third++;num++;}// 將臨時數組中的內容拷貝回原數組中 // (原left-right范圍的內容被復制回原數組) while (tmp <=right) { data[tmp] = tmpArrList[tmp];tmp++;} } public static void print(int[] data) { for (int i = 0; i < data.length; i++) { System.out.print(data[i] + " "); } System.out.println();} }

總結

以上是生活随笔為你收集整理的三路归并排序的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。