1 - JAVA實現(xiàn)桶排序

思路:

  1. 申請一個十個數(shù)的數(shù)組a溉跃,初始化每一項為0
  2. 讀入5個數(shù)撰茎,假如讀入的是3那就a[3]=1,表示3出現(xiàn)了一次炫惩,其他輸入同理
  3. 然后打印a[0]~a[10]他嚷,出現(xiàn)了幾次就打印幾次芭毙,
    比如a[1]=0退敦,表示沒有1這個數(shù)侈百,然后不打印,
    比如a[4]=2锭魔,表示4這個數(shù)出現(xiàn)了2次赂毯,打印2次
    ......
import java.util.Scanner;

/**
 * @author NIWA
 * 桶排序
 * 
 * 依次輸入5個數(shù)字,排序
 */
public class Main {

    public static void main(String[] args) {
        int[] a = new int[11];
        //初始化數(shù)組每一個為0
        for (int i = 0; i < a.length; i++) {
            a[i] = 0;
        }

        //分別輸入5個數(shù)字
        for (int i = 1; i <= 5; i++) {
            Scanner mScanner = new Scanner(System.in);
            int j = mScanner.nextInt();
            a[j]++;//計數(shù)
        }
        
        //依次判斷a[0]~a[10]
        for (int i = 0; i <= 10; i++) {
            for (int j = 0; j < a[i]; j++) {//出現(xiàn)了幾次就打印幾次,順序排,反著排也行上面一行改為
                System.out.println(i);
            }
        }
        
    }
}

但是這個有明顯的缺點肥荔,燕耿,假如現(xiàn)在有5個人的名字和分數(shù)嗎誉帅,
a-2右莱,
b-4亚再,
c-6氛悬,
d-8,
e-4帆谍,

從小到大排序后2-4-4-6-8
這樣就不知道人的排序而只是知道分數(shù)的排序


下面用List集合來改進算法烈涮,首先新建一個Bean類坚洽,


public class Bean {

        String name;
        int a;
    public Bean(int a, String name) {
        this.name = name;
        this.a = a;
    }
    public Bean(int a) {
        this.a = a;
    }
    
}

類似的讶舰,我們可以

public class Main {
    public static void main(String[] args) {
        //新建List集合般甲,用于存人名和分數(shù)的標記
        List<Bean> mList = new ArrayList<>();
        //初始化每一個List中的成績?yōu)?
        for (int i = 0; i < 10; i++) {
            mList.add(new Bean(0));
        }

        //分別輸入5個數(shù)字
        for (int i = 1; i <= 5; i++) {
            Scanner mScanner = new Scanner(System.in);
            int j = mScanner.nextInt();
            Scanner mScannerString = new Scanner(System.in);
            String name = mScannerString.nextLine();
            mList.get(j).a = 1;
            mList.get(j).name = name;
        }

        for (int i = 0; i < mList.size(); i++) {
            for (int j = 0; j < mList.get(i).a; j++) {
                System.out.println(i+mList.get(i).name);
            }
        }

    }
}

用List集合這樣子實現(xiàn)有一個缺點敷存,不能有重復的分數(shù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末帝雇,一起剝皮案震驚了整個濱河市尸闸,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌睹栖,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件豁辉,死亡現(xiàn)場離奇詭異徽级,居然都是意外死亡餐抢,警方通過查閱死者的電腦和手機现使,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來强重,“玉大人间景,你說我怎么就攤上這事拱燃⊥胗” “怎么了哮缺?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵尝苇,是天一觀的道長糠溜。 經(jīng)常有香客問我,道長红柱,這世上最難降的妖魔是什么蓖乘? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任零聚,我火速辦了婚禮容诬,結(jié)果婚禮上览徒,老公的妹妹穿的比我還像新娘习蓬。我一直安慰自己躲叼,他們只是感情好枫慷,可當我...
    茶點故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布笋婿。 她就那樣靜靜地躺著缸濒,像睡著了一般庇配。 火紅的嫁衣襯著肌膚如雪捞慌。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天萝快,我揣著相機與錄音旋恼,去河邊找鬼冰更。 笑死,一個胖子當著我的面吹牛舟铜,可吹牛的內(nèi)容都是我干的谆刨。 我是一名探鬼主播痊夭,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了矾踱?” 一聲冷哼從身側(cè)響起介返,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤圣蝎,失蹤者是張志新(化名)和其女友劉穎牲证,沒想到半個月后坦袍,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體等太,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年娩嚼,在試婚紗的時候發(fā)現(xiàn)自己被綠了岳悟。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖宽气,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情唆鸡,我是刑警寧澤争占,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布伯襟,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏肥卡。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一膨桥、第九天 我趴在偏房一處隱蔽的房頂上張望唠叛。 院中可真熱鬧只嚣,春花似錦艺沼、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽藐石。三九已至定拟,卻和暖如春于微,著一層夾襖步出監(jiān)牢的瞬間青自,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工恋腕, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留逆瑞,地道東北人荠藤。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓商源,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,969評論 2 355

推薦閱讀更多精彩內(nèi)容

  • //Clojure入門教程: Clojure – Functional Programming for the J...
    葡萄喃喃囈語閱讀 3,665評論 0 7
  • 1. Java基礎部分 基礎部分的順序:基本語法肴沫,類相關的語法颤芬,內(nèi)部類的語法,繼承相關的語法菱魔,異常的語法,線程的語...
    子非魚_t_閱讀 31,639評論 18 399
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)句各,斷路器,智...
    卡卡羅2017閱讀 134,657評論 18 139
  • 你活得不快樂的原因是:既無法忍受目前的狀態(tài)产禾,又沒能力改變這一切妄痪,可以像只豬一樣懶,卻無法像只豬一樣懶得心安理得西篓。 ???
    cbc699e201e9閱讀 145評論 0 0
  • 黑夜里 朗朗星空中 有一顆平凡的星 它不甘平凡 所以 它在努力的閃爍著 一閃一閃地 努力成為那一顆最出眾的星 如果...
    PQ零S閱讀 269評論 0 0