好程式設計師Java學習路線分享5分鐘瞭解基數排序
好程式設計師 Java 學習路線分享 5 分鐘瞭解基數排序, 前言: 基數排序無需進行比較和交換,而是利用分配和收集兩種基本操作實現排序。基數排序分為兩種:第一種是 LSD ,從最低位開始排序;第二種是 MSD , 從最高位開始排序。
基數排序思想介紹
- 分配:對於數字,每位的取值範圍是 0-9 ,因此需要 10 個容器(我們可以將其稱為桶),這 10 個桶標號為 0-9 。每趟排序時,我們取每一個元素在該位的數值依次放入桶中。
2. 收集:在一趟排序完成後,我們按順序從 0-9 的桶中依次取元素。
3. 繼續進行分配和收集,直到最大位數排序完成。
演算法說明:
待排序資料: 12, 34, 2, 123, 25, 59, 37
採用 LSD ,從低位開始排序
第一輪:取個位數,放入對應的桶,比如 12 的個位數是 2 ,放到 2 號桶; 34 的個位數是 4 ,放到 4 號桶
第一輪後,得到資料: 12, 2, 123, 34, 25, 37, 59
第二輪:取十位數,放入桶中。比如 2 ,十位數是 ,放到 號桶
第二輪後,得到資料: 2, 12, 123, 25, 34, 37, 59
第三輪:取百位數,放入桶
最後,得到有序資料 2, 12, 25, 34, 37, 59, 123
基數排序的程式碼實現
- private static void radixSort( int [] arr) {
- //儲存最大值,暫時記錄為第一個元素
- int max = arr[0];
- //獲取待排序陣列中的最大值
- for ( int v : arr) {
- if (v > max) {
- max = v;
- }
- }
- // 用列表表示桶,一共10個桶,每個桶對應的元素也是列表
- List<List<Integer>> list = new ArrayList<List<Integer>>();
- for ( int i = 0; i < 10; i ++) {
- list.add( new ArrayList<Integer>());
- }
- // 確定迴圈輪數
- for ( int i = 0, factor = 1; i < max; factor *= 10, i ++) {
- for ( int j = 0; j < arr.length; j ++) {
- // 根據相應的位(個位/十位...)取通號,然後將資料放入桶中
- list.get((arr[j] / factor) % 10).add(arr[j]);
- }
- // 遍歷桶,將其中資料放入arr陣列中
- for ( int j = 0, k = 0; j < list.size(); j ++) {
- while (!list.get(j).isEmpty()) {
- arr[k] = list.get(j).get(0);
- list.get(j).remove(0);
- k++;
- }
- }
- }
- }
總結
基數排序是一種按記錄關鍵字的各位值逐步進行排序的方法。一般適用於記錄的關鍵字為整數型別的情況,對於字串和文字排序不適合。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69913892/viewspace-2652971/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 好程式設計師Java學習路線分享5分鐘瞭解計數排序程式設計師Java排序
- 好程式設計師Java學習路線帶你5分鐘瞭解希爾排序程式設計師Java排序
- 好程式設計師Java學習路線分享SpringCloud程式設計師JavaSpringGCCloud
- 好程式設計師Java學習路線分享finalize()方法詳解程式設計師Java
- 好程式設計師Java乾貨分享5分鐘瞭解折半插入排序程式設計師Java排序
- 好程式設計師Java學習路線分享氣泡排序及最佳化程式設計師Java排序
- 好程式設計師Java教程教你5分鐘瞭解快速排序程式設計師Java排序
- 好程式設計師web前端學習路線分享瞭解AJAX是什麼程式設計師Web前端
- 好程式設計師Java學習路線分享mybatis對映程式設計師JavaMyBatis
- 好程式設計師Java學習路線分享如何處理中文引數程式設計師Java
- 好程式設計師Java學習路線分享Java框架怎麼搭建程式設計師Java框架
- 好程式設計師Java學習路線分享Java-String常用方法程式設計師Java
- 好程式設計師Java學習路線分享原生Ajax的使用程式設計師Java
- 好程式設計師Java學習路線分享JVM相關概念程式設計師JavaJVM
- 好程式設計師Java學習路線分享MyBatis之Spring整合程式設計師JavaMyBatisSpring
- 好程式設計師Java學習路線分享Redis快速入門程式設計師JavaRedis
- 好程式設計師Java學習路線分享MyBatis之基本使用程式設計師JavaMyBatis
- 好程式設計師Java學習路線分享maven是什麼程式設計師JavaMaven
- 好程式設計師Java學習路線分享SpringMVC之MVC概述程式設計師JavaSpringMVC
- 好程式設計師web前端學習路線分享Jsonp詳解程式設計師Web前端JSON
- 好程式設計師Java學習路線分享Java中的位移運算程式設計師Java
- 好程式設計師Java學習路線分享三大特性之多型程式設計師Java多型
- 好程式設計師Java學習路線分享Dubbo架構介紹程式設計師Java架構
- 好程式設計師Java學習路線分享多執行緒概念程式設計師Java執行緒
- 好程式設計師Java學習路線分享MySQL目錄結構程式設計師JavaMySql
- 好程式設計師web前端學習路線分享函式基礎程式設計師Web前端函式
- 好程式設計師Python學習路線分享實現快速排序演算法程式設計師Python排序演算法
- 好程式設計師Java學習路線之集程式設計師Java
- 好程式設計師Java學習路線JSP物件程式設計師JavaJS物件
- 好程式設計師大資料學習路線分享AWK詳解程式設計師大資料
- 好程式設計師Java學習路線分享Java弱引用的理解與使用程式設計師Java
- 好程式設計師Java學習路線分享Java案例-封裝JDBC工具類程式設計師Java封裝JDBC
- 好程式設計師Java學習路線分享怎麼理解Java物件導向程式設計師Java物件
- 好程式設計師Java學習路線分享SpringMVC之請求和響應程式設計師JavaSpringMVC
- 好程式設計師Java學習路線分享MyBatis之關聯查詢程式設計師JavaMyBatis
- 好程式設計師Java學習路線分享JVM類載入機制程式設計師JavaJVM
- 好程式設計師Java學習路線分享Spring常見面試題程式設計師JavaSpring面試題
- 好程式設計師大資料學習路線分享MAPREDUCE程式設計師大資料