# åºæ°æåº åºæ°æåºæ¯ä¸ç§éæ¯è¾åæ´æ°æåºç®æ³ï¼å ¶åçæ¯å°æ´æ°æä½æ°å岿ä¸åçæ°åï¼ç¶åææ¯ä¸ªä½æ°å嫿¯è¾ãç±äºæ´æ°ä¹å¯ä»¥è¡¨è¾¾åç¬¦ä¸²ï¼æ¯å¦ååææ¥æï¼åç¹å®æ ¼å¼çæµ®ç¹æ°ï¼æä»¥åºæ°æåºä¹ä¸æ¯åªè½ä½¿ç¨äºæ´æ°ã ## 1. åºæ°æåº vs è®¡æ°æåº vs æ¡¶æåº åºæ°æåºæä¸¤ç§æ¹æ³ï¼ è¿ä¸ç§æåºç®æ³é½å©ç¨äºæ¡¶çæ¦å¿µï¼ä½å¯¹æ¡¶çä½¿ç¨æ¹æ³ä¸æææ¾å·®å¼ï¼ - åºæ°æåºï¼æ ¹æ®é®å¼çæ¯ä½æ°åæ¥åé æ¡¶ï¼ - è®¡æ°æåºï¼æ¯ä¸ªæ¡¶åªåå¨åä¸é®å¼ï¼ - æ¡¶æåºï¼æ¯ä¸ªæ¡¶åå¨ä¸å®èå´çæ°å¼ï¼ ## 2. LSD åºæ°æåºå¨å¾æ¼ç¤º  ## 3. JavaScript 代ç å®ç° ```js //LSD Radix Sort var counter = []; function radixSort(arr, maxDigit) { var mod = 10; var dev = 1; for (var i = 0; i < maxDigit; i++, dev *= 10, mod *= 10) { for(var j = 0; j < arr.length; j++) { var bucket = parseInt((arr[j] % mod) / dev); if(counter[bucket]==null) { counter[bucket] = []; } counter[bucket].push(arr[j]); } var pos = 0; for(var j = 0; j < counter.length; j++) { var value = null; if(counter[j]!=null) { while ((value = counter[j].shift()) != null) { arr[pos++] = value; } } } } return arr; } ``` ## 4. Java 代ç å®ç° ```java /** * åºæ°æåº * èèè´æ°çæ åµè¿å¯ä»¥åèï¼ https://code.i-harness.com/zh-CN/q/e98fa9 */ public class RadixSort implements IArraySort { @Override public int[] sort(int[] sourceArray) throws Exception { // 对 arr è¿è¡æ·è´ï¼ä¸æ¹ååæ°å 容 int[] arr = Arrays.copyOf(sourceArray, sourceArray.length); int maxDigit = getMaxDigit(arr); return radixSort(arr, maxDigit); } /** * è·åæé«ä½æ° */ private int getMaxDigit(int[] arr) { int maxValue = getMaxValue(arr); return getNumLenght(maxValue); } private int getMaxValue(int[] arr) { int maxValue = arr[0]; for (int value : arr) { if (maxValue < value) { maxValue = value; } } return maxValue; } protected int getNumLenght(long num) { if (num == 0) { return 1; } int lenght = 0; for (long temp = num; temp != 0; temp /= 10) { lenght++; } return lenght; } private int[] radixSort(int[] arr, int maxDigit) { int mod = 10; int dev = 1; for (int i = 0; i < maxDigit; i++, dev *= 10, mod *= 10) { // èèè´æ°çæ åµï¼è¿éæ©å±ä¸åéåæ°ï¼å ¶ä¸ [0-9]对åºè´æ°ï¼[10-19]å¯¹åºæ£æ° (bucket + 10) int[][] counter = new int[mod * 2][0]; for (int j = 0; j < arr.length; j++) { int bucket = ((arr[j] % mod) / dev) + mod; counter[bucket] = arrayAppend(counter[bucket], arr[j]); } int pos = 0; for (int[] bucket : counter) { for (int value : bucket) { arr[pos++] = value; } } } return arr; } /** * èªå¨æ©å®¹ï¼å¹¶ä¿åæ°æ® * * @param arr * @param value */ private int[] arrayAppend(int[] arr, int value) { arr = Arrays.copyOf(arr, arr.length + 1); arr[arr.length - 1] = value; return arr; } } ```