C語言學習之桶排序

來源:互聯網
上載者:User

標籤:就是   class   style   簡單   scan   blog   還需   nbsp   序列   

 

  之前的博文寫了交換(冒泡)排序、選擇排序,本文就寫寫桶排序。不過我理解的這樣不算是真正上的桶排序,我的比較簡單而真正的桶排序是比較複雜的,暫且就叫桶排序吧。

  桶排序在排序中應該用的不多吧,個人理解的是比較簡單易懂的,針對小量資料的排序很有用,不過有個小缺點就是只適合在螢幕上列印輸出,實際的應用中我們是利用這樣排列好之後的資料,我想這就是桶排序應用場合比較少的原因吧。

  就簡單講講吧,故名思意 桶排序就是一排帶有序列編號的的桶子,而這編號的範圍就是將我們要排序資料包括在內。在我們輸入資料的時會在與輸入資料相同編號的桶上標記一次,每次輸入資料都在與資料相同編號的桶上標記一次,這樣每個資料出現的次數就顯而易見了,同時排序也好了,我們按照編號順序依次把沒有標記的桶子排除,再根據桶子標記的次數列印等量次數就行了。

 

#include"stdio.h"int main(void){    int i, j;    int n, b[10] = {};//首先將所有桶的標記都重設為 0    for(j = 0; j < 10; j ++)    {        scanf("%d", &n);//依次讀入10個資料        b[n] ++;    }    for(i = 0; i < 10; i ++)            for(j = 0; j < b[i]; j ++)//根據次數列印資料 
                   //沒有標記的為0那麼就不會列印出來 printf("%d ", i);}

 

  當然這裡以10以內的資料為例 如輸入 4 4 5 6 1 0 4 4 6 8 輸出結果為 0 1 4 4 4 4 5 6 6 8

  在運用就自行調整資料範圍,更改數組的大小、更改for的範圍使之剛好可以把最值包含在內,這樣至少可以省點時間。

#include"stdio.h"//排序四位元int main(void){    int i, j;    int n, b[10000] = {};//調整數組大小    for(j = 0; j < 10; j ++)    {        scanf("%d", &n);//依次讀入10個資料        b[n] ++;    }    for(i = 1000; i < 10000; i ++)//調整範圍            for(j = 0; j < b[i]; j ++)            printf("%d ", i);}

  如上修改了一下 就可以用來排序四位元 輸入資料 3234 6535 8743 9876 4567 5466 5434 2345 8798 4323 輸入結果為 2345 3234 4323 4567 5434 5466 6535 8743 8798 9876

  實際運用就實際修改咯 我個人理解的桶排序是很簡單的 但真正的桶排序是有點複雜的 筆者只是瞭解下 如要深入還需自行百度 Google 哈

 

C語言學習之桶排序

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.