桶排序算法c語言10個數組,桶排序算法

該樓層疑似違規已被系統折疊?隱藏此樓查看此樓

//2.21 桶排序

#include

#include

#define SIZE 100

void bucket_sort(unsigned *,int);//桶排序函數的原型

void print(unsigned *,int);//打印函數的原型

int main()

{

unsigned array[SIZE];

int i=0;

//為數組元素隨機賦值

for(i=0;i

array[i]=rand();

printf("排序前\n");

print(array,SIZE);

//排序

bucket_sort(array,SIZE);

printf("排序后\n");

print(array,SIZE);

return 0;

}

void bucket_sort(unsigned * arr,int len)

{

unsigned *buckets[10];//指針數組

unsigned n=1;//用于取整數各位上的值

int index;//數組下標計數索引

int indexs[10];//各個桶下標計數索引

int i,j;

//分配動態內存作為桶

for(i=0;i<10;++i)

buckets[i]=(unsigned *)malloc(sizeof(unsigned)*len);

while(1)

{

//計數索引清零

index=0;

for(i=0;i<10;++i)

indexs[i]=0;

//數組至桶

for(i=0;i

buckets[arr[i]/n%10][indexs[arr[i]/n%10]++]=arr[i];

//桶至數組

for(i=0;i<10;++i)

for(j=0;j

arr[index++]=buckets[i][j];

//為取元素的下一位做準備

n*=10;

//判斷是否該結束

for(i=0;arr[i]

if(i==len) break;

}

//釋放動態內存

for(i=0;i<10;++i)

free(buckets[i]);

}

void print(unsigned * arr,int len)

{

int i=0;

for(i=0;i

{

printf("%8d",arr[i]);

//5個元素一行

if((i+1)%5==0)

printf("\n");

}

}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531883.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531883.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531883.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

diabetes影響因子2017_Journal of Diabetes

英文簡介&#xff1a;Journal of Diabetes (JDB) devotes itself to diabetes research, therapeutics, and education. It aims to involve researchers and practitioners in a dialogue between East and West via all aspects of epidemiology, etiology, pathogenesis, ma…

java中泛型上限,下限應用

v 一.程序中無形之中用到的泛型import java.util.*; class Person implements Comparable<Person>{String name;int age;Person(){name "";age 0;}Person(String name, int age){this.name name;this.age age;}public String toString(){return name &quo…

株洲c語言培訓機構,株洲好就業的學c語言程序設計,計算機專業地址

株洲好就業的學c語言程序設計衡陽市瀟湘職業中等專業學校是由衡陽市教育主管&#xff0c;在衡陽校區的基礎上設置的一所綜合性全日制中等職業學校。坐落在國內優秀旅游城市、國內高新技術產業基地、名人輩出的全國歷史文化名城-----衡陽市。我校依托長沙醫校院&#xff0c;實現…

er圖外鍵怎么表示_本周話題:取消考研復試最能實現相對公平?你怎么看?

2020取消研究生復試的呼聲越來越高&#xff1f;考研er們&#xff1a;壓力太大&#xff01;近日&#xff0c;紅網作者李詩元的一篇《取消考研復試最能實現相對公平》引起熱議國家線的出臺和調劑系統5月20日的才開的通知讓大家直接炸開了郭就山西大學來說 往年都是調劑生和一志愿…

java中匿名類的注意細節

abstract class Outer{int num;public Outer(int x){num x;}public abstract void show1();public abstract void show2(); }public class PC{public static void main(String[] args){new Outer(55)//構造父類部分//子類重寫部分{public void show1(){System.out.println(num…

ios沙箱模式開啟_iOS沙盒篇

iOS系統在安全性上的一大亮點就是沙盒。每個iOS應用SDK都被限制在沙盒中&#xff0c;我們可以把沙盒當成一個設置了僅當前SDK可以訪問的文件夾&#xff0c;蘋果對沙盒有以下幾條限制&#xff1a;應用程序可以在自己的沙盒中運行&#xff0c;但不能訪問任何其他應用程序的沙盒。…

c語言不定方程的二元一次,poj1061 - 同余方程,二元一次不定方程

以前不會解二元一次不定方程的時候不會做&#xff0c;現在會做了。#include #include using namespace std;typedef __int64 int64;void solveType1(int64 a, int64 b, int64 & x, int64 & y, int64 & d) {if (b 0) {x 1; y 0; d a;return;}int64 _x, _y, _d;s…

java中異常注意的細節1

/* public class Test{public static void main(String[] args){int i0;try{func();//區別就是該函數拋出的異常被封裝了&#xff0c;外界不知道到底會不會發生該異常System.out.println("i " i);//所以這句話是有機會執行的}catch(Exception e){System.out.printl…

append 后如何刪除_如何在STATA中合并數據文件呢?

?作者&#xff1a;江小白郵箱&#xff1a;jieresearch163.com?我們在使用stata進行數據分析時&#xff0c;可能涉及多個數據文檔的合并操作或者同時使用不同數據集中的多個變量&#xff0c;這都需要我們進行文檔間不同變量的歸并。例如&#xff0c;我們需要使用CFPS(中國家庭…

linux 內網怎么安裝git環境_linux 安裝go環境

官網下載安裝包The Go Programming Language?golang.google.cngo1.4.linux-amd64.tar.gz解壓&#xff1a;tar -C /usr/local -zxvf go1.4.linux-amd64.tar.gz添加環境變量&#xff1a;export PATH$PATH:/usr/local/go/bin安裝完成輸入go測試安裝成功&#xff0c;寫個簡單的代碼…

java中異常注意問題(發生在多態是的異常問題)

/* 異常的注意事項&#xff1a; 1&#xff0c;子類在覆蓋父類方法時&#xff0c;父類的方法如果拋出了異常&#xff0c;那么子類的方法只能拋出父類的異常或者該異常的子類。 2&#xff0c;如果父類拋出多個異常&#xff0c;那么子類只能拋出父類異常的子集。 簡單說&#xff1…

cups支持的打印機列表_Win10“Microsoft Print to PDF”虛擬打印機不見了,如何找回?...

MS酋長很早以前在介紹Windows10的新功能時&#xff0c;就提到過《Win10原生支持把文件轉換成PDF格式》&#xff0c;該功能實際上是基于“Microsoft Print to PDF”虛擬打印機來實現的。當你點擊打印時&#xff0c;在打印機列表中就可以看到“Microsoft Print to PDF”虛擬打印機…

循環隊列的進隊算法c語言,循環隊列的定義,入隊算法,出隊算法,遍歷算法,及其代碼實現-Go語言中文社區...

隊列 的定義&#xff1a;一種可以是實現“先進先出”的存儲結構。數據的進出類似于排隊購票。隊只允許隊尾一端(rear)添加&#xff0c;在另一端隊頭(front)刪除。隊有隊頭(front)和隊尾(rear)兩個指針。隊頭front指向第一個元素&#xff0c;隊尾rear指向無實際意義的元素&#…

java中paint方法和paintComponent方法的不同

/*1.由Component.java源代碼中可以看見其中的paint&#xff08;&#xff09;方法體是空的&#xff0c;在Container中重寫了該方法&#xff0c;其子類Window等也重寫了該方法2.由JComponent.java源代碼中可以看見其中的paint()方法中調用paintComponent, paintChildren, paintBo…

java office文件加水印_文檔預覽加水印——或可一用的防泄密方式

給文件加水印是常見的一種宣示版權的方式。像Office、WPS都自帶加水印功能&#xff0c;能夠給文檔加上"保密"、"嚴禁復制"這樣的水印。在多可系統中&#xff0c;也有這么一個添加水印的功能。啟用該功能后&#xff0c;在使用HTML5預覽時&#xff0c;多可系…

android 獲取apk資源,android-apk-parser

APK解析庫用于讀取/解析 packageName。versionName。versionCode信息的簡單類&#xff0c;以及已經編譯的androidsdk文件中的更多內容。通過解壓 AndroidManifest.xml 文件并解碼編譯好的XML二進制文件來收集這里信息&#xff0c;就可以實現。我一直在用它來實現各種android工件…

apache license 2.0如何使用防止法律糾紛_go語言使用Swaggo詳細教程

相信很多程序猿和我一樣不喜歡寫API文檔。寫代碼多舒服&#xff0c;寫文檔不僅要花費大量的時間&#xff0c;有時候還不能做到面面具全。但API文檔是必不可少的&#xff0c;相信其重要性就不用我說了&#xff0c;一份含糊的文檔甚至能讓前后端人員打起來。 而今天這篇博客介紹的…

靜態代碼塊,構造代碼塊,局部代碼塊演示

public class Test{static int num;static int numObj;//記錄有多少個對象產生&#xff01;static{//靜態代碼塊&#xff0c; 是用來給類進行初始化的&#xff01;//num 10;num;num *12;//沒有進入靜態代碼塊之前&#xff0c;num的初始化值是0System.out.println(num);//main(…

android執行main函數,AndroidStudio執行main方法報錯

問題&#xff1a;有時在開發中想直接寫一個java文件來測試一些東西&#xff0c;但是AndroidStudio執行的時候會報錯。代碼信息&#xff1a;public class HelloWorld {public static void main(String[] args) {System.out.println("HelloWorld");}}報錯信息12:04:41:…

模擬java.util.Collection一些簡單的用法

/* 需求&#xff1a;模擬java.util.Collection一些簡單的用法&#xff01;注意&#xff1a;java虛擬機中并沒有泛型類型的對象。泛型是通過編譯器執行一個被稱為類型擦除的前段轉換來實現的。 1&#xff09;用泛型的原生類型替代泛型。 原生類型是泛型中去掉尖括號及其中的類型…