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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java radix sort_用于Radix Sort的Java程序

發布時間:2024/9/27 java 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java radix sort_用于Radix Sort的Java程序 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

基數排序是一種排序技術,可根據每個元素(或數字)中的每個數字對元素進行排序。基于一個位數(也稱為最低有效位數)和十位數(也稱為最高有效位數),數百個位數等等,對元素進行排序。

示例

以下是Java中Radix Sort的示例-import?java.util.*;

public?class?my_radix_sorting?{

static?int?get_max_val(int?my_arr[],?int?arr_len)?{

int?max_val?=?my_arr[0];

for?(int?i?=?1;?i?

if?(my_arr[i]?>?max_val)

max_val?=?my_arr[i];

return?max_val;

}

static?void?countSort(int?my_arr[],?int?arr_len,?int?exp)?{

int?result[]?=?new?int[arr_len];

int?i;

int?count[]?=?new?int[10];

Arrays.fill(count,0);

for?(i?=?0;?i?

count[?(my_arr[i]/exp)%10?]++;

for?(i?=?1;?i?

count[i]?+=?count[i?-?1];

for?(i?=?arr_len?-?1;?i?>=?0;?i--)?{

result[count[?(my_arr[i]/exp)%10?]?-?1]?=?my_arr[i];

count[?(my_arr[i]/exp)%10?]--;

}

for?(i?=?0;?i?

my_arr[i]?=?result[i];

}

static?void?radix_sort(int?my_arr[],?int?arr_len)?{

int?m?=?get_max_val(my_arr,?arr_len);

for?(int?exp?=?1;?m/exp?>?0;?exp?*=?10)

countSort(my_arr,?arr_len,?exp);

}

public?static?void?main?(String[]?args)?{

int?my_arr[]?=?{56,?78,?102,?345,?67,?90,?102,?45,?78};

int?arr_len?=?my_arr.length;

System.out.println("The?array?after?performing?radix?sort?is?");

radix_sort(my_arr,?arr_len);

for?(int?i=0;?i

System.out.print(my_arr[i]+"?");

}

}

輸出結果The?array?after?performing?radix?sort?is

45?56?67?78?78?90?102?102?345

說明

在基數排序中,每個元素均基于其數字進行排序,其中每個元素中的最低有效數字首先被排序,而最高有效數字最后被排序。它使用計數排序作為子功能來執行其排序功能。

給定一個元素數組,第一步是根據最低有效位的數字(即一個位)對元素進行排序。接下來,根據十位數字對數組中的元素進行排序。然后,根據數百位數字對元素進行排序,依此類推。這是借助“ get_max_val”功能完成的。在main函數中,定義了數組,并將該數組作為參數傳遞給“ radix_sort”函數。

總結

以上是生活随笔為你收集整理的java radix sort_用于Radix Sort的Java程序的全部內容,希望文章能夠幫你解決所遇到的問題。

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