真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

好程序員Java學(xué)習(xí)路線分享5分鐘了解計數(shù)排序

好程序員Java學(xué)習(xí)路線分享5分鐘了解計數(shù)排序,前言:計數(shù)排序是一種非比較性質(zhì)的排序算法,計數(shù)排序借助輔助空間記錄每個元素出現(xiàn)的次數(shù),根據(jù)次數(shù)確定每一個元素最終的位置。
計數(shù)排序思想介紹
1根據(jù)待排序數(shù)組,獲取最大值和最小值,得到所有元素的范圍 [m,n]
2新建一個長度為n-m+1的臨時數(shù)組
3遍歷待排序數(shù)組,元素的值-m作為臨時數(shù)組下標,該下標位置記錄元素出現(xiàn)次數(shù)
4遍歷結(jié)束,臨時數(shù)組就存儲了每個元素出現(xiàn)的次數(shù)
5根據(jù)該臨時數(shù)組,最終得到排序后元素

創(chuàng)新互聯(lián)“設(shè)計定江山,服務(wù)贏天下“的思想,用細節(jié)和態(tài)度獲得客戶的認可與同行的尊重,服務(wù)是創(chuàng)新互聯(lián)企業(yè)文化中重要的核心思想,每一位員工要致力成為客戶心中堅實的服務(wù)后盾。

算法說明:
待排序數(shù)據(jù):12,4,6,7,4,6
數(shù)據(jù)范圍為[4,12],臨時數(shù)組長度為12-4+1=9
好程序員Java學(xué)習(xí)路線分享5分鐘了解計數(shù)排序

最終得到排序后序列:4,4,6,6,7,12
計數(shù)排序的代碼實現(xiàn)
1.public?static?void?sortCount(int[]?arr)?{??
2.????????int?max?=?0;??
3.????????int?min?=?0;??
4.????????//?獲取數(shù)組的最大值和最小值??
5.????????for(int?i?=?0;?i?6.????????????max?=?Math.max(max,?arr[i]);??
7.????????????min?=?Math.min(min,?arr[i]);??
8.????????}??
9.????????int?len?=?arr.length;??
10.????????//?創(chuàng)建臨時數(shù)組??
11.????????int[]?temp?=?new?int[max?-?min?+?1];??
12.????????//?計數(shù)??
13.????????for(int?i?=?0;?i?14.????????????temp[arr[i]?-?min]?+=?1;??
15.????????}??
16.????????//?將臨時數(shù)組中數(shù)據(jù)依次放回原數(shù)組??
17.????????for(int?i?=?0,?index?=?0;?i?18.????????????int?item?=?temp[i];??
19.????????????while(item--?!=?0)?{??
20.????????????????arr[index++]?=?i?+?min;??
21.????????????}??
22.????????}??
23.????}??

總結(jié)
計數(shù)排序需要占用額外的存儲空間,它比較適用于數(shù)據(jù)比較集中的情況。


分享文章:好程序員Java學(xué)習(xí)路線分享5分鐘了解計數(shù)排序
當(dāng)前網(wǎng)址:http://weahome.cn/article/igoopo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部