當前位置:首頁 » 編程語言 » 基數排序c語言代碼
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

基數排序c語言代碼

發布時間: 2022-01-15 18:00:42

『壹』 c語言基數排序問題沒有指針的int radixsort函數

正常的實現使用鏈表或者數組把個位數字重復的數字鏈接一起的,像下面這樣


給你一個使用例子。

const kNum =10;

int a [kNum] = { 7,6,64, 100,343,633,454,465,45,23};

int link [kNum] = {0};

int first = radixSort (a, link,3, 10,kNum);


printf ("排序的結果是:");

int next =first;

do {

printf ("%d ", a[next]);

next = link[next];

} while (next !=0]);

『貳』 用c語言編寫一個排序程序,要求使用基數排序演算法,最好能詳細解釋下,c語言初學者

#include<stdio.h>
#defineMAX_NUM_OF_KEY8//關鍵字項數的最大值
#defineRADIX10//關鍵字基數,此時是十進制整數的基數
#defineMAX_SPACE10000
typedefintKeysType;
typedefintInfoType;

typedefstruct
{
KeysTypekeys;//關鍵字
InfoTypeotheritems;//其它數據項
intnext;
}SLCell;
typedefstruct
{
SLCellr[MAX_SPACE];//靜態鏈表的可利用空間,r[0]為頭結點
intkeynum;//記錄當前關鍵字個數
intrecnum;//靜態鏈表的當前長度
}SLList;//靜態鏈表類型

typedefintArrType[RADIX];//指針數組類型

intord(KeysTypekey,intdigitally)
{
inti;

if(digitally)
{//根據位數,返回不同的數位
for(i=0;i<digitally;++i)
{
key/=10;
}
}
returnkey%10;
}


voidDistribute(SLCell*r,inti,ArrTypef,ArrTypee)
{
//靜態鏈表L的r域中記錄已按keys[0].....keys[i-1]有序。
//本演算法按第i個關鍵字keys[i]建立RADIX個子表,使同一子表中記錄的keys[i]相同
//f[0..RADIX-1]和e[0..RADIX-1]分別指向各子表中第一個和最後一個記錄
intj,p;

for(j=0;j<RADIX;++j)
{
f[j]=e[j]=0;//初始化指針
}
for(p=r[0].next;p;p=r[p].next)
{
j=ord(r[p].keys,i);//取得相應數位上的值
if(!f[j])
f[j]=p;//頭指針為空,則取得結點位置
else
r[e[j]].next=p;//原來的尾指針指向第i位數相同的新結點
e[j]=p;//尾指指向新結點作為最後結點
}
}

voidCollect(SLCell*r,inti,ArrTypef,ArrTypee)
{
//本演算法按keys[i]自小至大地將f[0..radix-1]所指各子表依次鏈接成一個鏈表
//e[0..radix-1]為各子有的尾指針
intj,t;

for(j=0;!f[j];++j);//找第一個非空子表
r[0].next=f[j];//r[0].next指向第一個非空結點
t=e[j];
while(j<RADIX-1)
{
for(j=j+1;j<RADIX-1&&!f[j];++j);//找下一個非空子表
if(f[j])
{
r[t].next=f[j];//鏈接兩非空子表
t=e[j];//指向尾結點
}
}
r[t].next=0;//t指向最後一個非空子表中的最後一個結點
}

voidRadixSort(SLList*L)
{
//L是採用靜態鏈表表示的順序表
//對L作基數排序,使得L成為按關鍵字自小到大的有序靜態鏈表,
//L.r[0]為頭結點
inti;
ArrTypef,e;

for(i=0;i<L->recnum;++i)
{
L->r[i].next=i+1;
}
L->r[L->recnum].next=0;//L改造為靜態鏈表
for(i=0;i<L->keynum;++i)//按最低位優先依次對各關鍵字進行分配和收集
{
Distribute(L->r,i,f,e);//第i趟分配
Collect(L->r,i,f,e);//第i趟收集
}
}

intmain(void)
{
KeysTypearr[]={69,17,63,32,27,73,49,53},temp;
SLListL;
inti,nLen,nCount;

nCount=0;
nLen=sizeof(arr)/sizeof(KeysType);
L.recnum=nLen;//取得關鍵字個數
temp=arr[0];
while(temp)
{
temp/=10;
nCount++;
}
L.keynum=nCount;//取得數據位數

for(i=0;i<L.recnum;++i)
{
L.r[i+1].keys=arr[i];//取得元素
}
RadixSort(&L);
for(i=L.r[0].next;i;i=L.r[i].next)
{
printf("%d ",L.r[i].keys);
}
return0;
}

以前學嚴蔚敏時的代碼,當時寫了些注釋,慢慢看應該能理解。

『叄』 鏈式基數排序的演算法思想(C語言),越多越仔細越好

參考
/* 基數排序的演算法源程序*/
#include <stdio.h>
#define D 3 /* D為排序碼的最大位數 */
#define R 10 /* R為基數 */
typedef int KeyType;
typedef int DataType;
struct Node; /* 單鏈表結點類型 */
typedef struct Node RadixNode;
struct Node {
KeyType key[D];
/* DataType info;*/
RadixNode *next;
};
typedef RadixNode * RadixList;
typedef struct QueueNode {
RadixNode *f; /* 隊列的頭指針 */
RadixNode *e; /* 隊列的尾指針 */
} Queue;
Queue queue[R];
void radixSort(RadixList * plist, int d, int r) {
int i,j,k;
RadixNode *p, *head = (*plist)-> next;
for(j = d-1; j > = 0; j--) { /* 進行d次分配和收集*/
p = head;
for(i = 0; i < r; i++) {
queue[i].f = NULL; queue[i].e = NULL; /* 清隊列 */
}
while (p != NULL) {
k = p-> key[j]; /* 按排序碼的第j個分量進行分配*/
if (queue[k].f == NULL)
queue[k].f = p; /* 若第k個隊列為空,則當前記錄為隊頭*/
else (queue[k].e)-> next = p;/* 否則當前記錄鏈接到第k隊的隊尾*/
queue[k].e = p;
p = p-> next;
}
for(i = 0; queue[i].f == NULL; i++) /* 找出第一個非空隊列*/
;
p = queue[i].e; head = queue[i].f; /* head為收集鏈表的頭指針*/
for(i++; i < r; i++)
if(queue[i].f != NULL) { /* 收集非空隊列 */
p-> next = queue[i].f;
p = queue[i].e;
}
p-> next = NULL;
}
(*plist)-> next = head;
}
struct Node element[11]={
0,0,0,NULL,/*表頭*/
0,3,6,NULL,/*36*/
0,0,5,NULL,/*5*/
0,1,6,NULL,/*16*/
0,9,8,NULL,/*98*/
0,9,5,NULL,/*95*/
0,4,7,NULL,/*47*/
0,3,2,NULL,/*32*/
0,3,6,NULL,/*36*/
0,4,8,NULL,/*48*/
0,1,0,NULL /*10*/
};
int main(){
int i;
RadixList p = element;
for (i = 0; i < 10; i++)
element[i].next = &element[i+1];
element[10].next = NULL;
radixSort(&p, 3, 10);
p = p-> next;
while (p != NULL){
printf( "%d ", p-> key[1]*10+p-> key[2]);
p = p-> next;
}
getchar();
return 0;
}

『肆』 用C語言描述如何實現基數排序。是數據結構課程設計作業

/*
1.基數是利用同位比較的排序演算法,時空復雜度都比較低,很適合字母字元串排序
2.比如對int數組用以1和0為基數排序,先比較第一位,0位靠前1位靠後,一直排完32位
3.基數排序不需要特殊的數據結構
4.只需一個函數即能完成基數排序
5.給個郵箱發源碼,手機不知道怎麼上傳附件
6.對於百萬級的數據,效率和快速排序相仿,但使用空間低很多,並且在串大小比較方面具有其他排序演算法無法匹敵的性能

整理一下代碼,終於獨立出來了,如果覺得可以就採納吧
*/

#define elapser

#define debug

//#define descend

#ifndef descend
#define ascend
#endif

#define count_max 0x7fffffff
#define count_min 0x00000002

#define step_default 0x80000000

int radixsort (unsigned int* pdata ,unsigned int count)
{
void radix (unsigned int* pfirst ,unsigned int* plast ,unsigned int step) ;

if (pdata == 0 || count < count_min || count > count_max)
return -1 ;

radix (pdata ,pdata + count - 1 ,step_default) ;

return 0 ;
}

void radix (unsigned int* pfirst ,unsigned int* plast ,unsigned int step)
{
unsigned int* pleft = pfirst ;
unsigned int* pright = plast ;

while (1)
{
#ifdef descend
while ((*pleft & step) && pleft < pright)
#else
while (!(*pleft & step) && pleft < pright)
#endif
pleft++ ;

#ifdef descend
while (!(*pright & step) && pleft < pright)
#else
while ((*pright & step) && pleft < pright)
#endif
pright-- ;

if (pleft >= pright)
break ;

*pleft ^= *pright ;
*pright ^= *pleft ;
*pleft ^= *pright ;

pleft++ ;
pright-- ;
}

if (pleft > pright)
{
pleft-- ;
pright++ ;
}
else
#ifdef descend
if (!(*pleft & step))
#else
if (*pleft & step)
#endif
pleft-- ;
else
pright++ ;

if (!(step >>= 1))
return ;

if (pleft > pfirst)
radix (pfirst ,pleft ,step) ;

if (pright < plast)
radix (pright ,plast ,step) ;

return ;
}

#ifdef debug

#define data_count 1000000

int main ()
{
int radixsort (unsigned int* pdata ,unsigned int count) ;

unsigned int data[data_count] ;

unsigned int* p = data ;
unsigned int* pe = p + data_count ;

srand ((unsigned int) time (0)) ;

while (p < pe)
*p++ = (unsigned int) rand () & 0x0000000f ;

int itime = time (0) ;
int iresult = radixsort (data ,data_count) ;
itime = time (0) - itime ;

for (p = data ; p < pe ; p++)
printf ("%u ," ,*p) ;

printf ("\n") ;

printf ("task was completed in %d seconds while result is %d\n" ,itime ,iresult) ;

printf ("this radixsort routine is made by elapser\nplease choose my anwser if it helps\n") ;

return 0 ;
}

#endif

『伍』 c語言歸並排序,基數排序

void merge(int *a, int low, int center, int high){
int m,n,i,j,k;
int *L,*R;
if(low >= high) return;
m = center - low + 1;
n = high - center;
L = (int *)malloc(m * sizeof(int));
R = (int *)malloc(n * sizeof(int));
for(i=0; i<m; ++i) L[i] = a[low+i];
for(i=0; i<n; ++i) R[i] = a[low+i+m];
for(i=0,j=0,k=low; i<m && j<n;++k) {
if(L[i] > R[j])
a[k] = R[j++];
else
a[k] = L[i++];
}
while(i<m) a[k++] = L[i++];
while(j<n) a[k++] = R[j++];
}
void m_sort(int *a, int low, int high){
int center;
if(low < high) {
center = (low + high)/2;
m_sort(a, low, center);
m_sort(a, center+1, high);
merge(a, low, center, high);
}
}
int main(){
int i;
int a[] = {23, 2, 45, 78, 1, 99, 3,65,43,55};
m_sort(a, 0, 6);
for(i=0; i<10; ++i) {
printf("%d ",a[i]);
}
return 0;
}

『陸』 C語言,基數排序

#include <stdio.h>

typedef struct node {
int data;
int next;
} node;

int head; //這里的head是全局變數
int fr[10];
int re[10];

void Distribute(node *a, int w) //第一次w=1
{
int i;
for (i=0; i<10; i++) { //初始化
fr[i] = -1;
}
for (i=head; i!=-1; i=a[i].next) { //第一次i=0
int x = a[i].data / w % 10; //這是以前求一個數各個位的方法例:98%10=8(個位) 98/10%10=9(十位)

if (fr[x] == -1) {
fr[x] = re[x] = i;
}
else {
a[re[x]].next = i;
re[x] = i;
}
}
for (i=0; i<10; i++) {
if (fr[i] != -1) {
a[re[i]].next = -1;
}
}
}

void Collect(node *a)
{
int i, last;

last = -1;
for (i=0; i<10; i++) {
if (fr[i] != -1) {
if (last == -1) {
head = fr[i];
last = re[i];
}
else {
a[last].next = fr[i];
last = re[i];
}
}
}
a[last].next = -1;
}

void Out(node *a, int w)
{
int i, p, k;

printf("weight == %d\n", w);
for (i=0; i<10; i++) {
printf("fr[%d] ", i);
p = fr[i];
k = 0;
while (p != -1) {
printf("->%4d ", a[p].data);
p = a[p].next;
k++;
}
while (k<3) printf("-------"),k++;
printf("-> re[%d]\n", i);
}
}

void Output(node *a, int head) //結構體指針 ,這里的head是形參,調用此函數結束後即釋放,不影響全局變數head的值
{
while (head != -1) {
printf("%4d", a[head].data);
head = a[head].next;
}
printf("\n");
}

void main()
{
//對於無數據的數組排序會出錯~~~
//614 738 921 485 637 101 215 530 790 306
node a[10]; //結構體數組
int i, n = 10, max;
max = 0x80000000; //此處對0x80000000及MAX的意思不理解
printf("max == %d\n", max);
printf("Please intput %d numbers~\n", n);
for (i=0; i<n; i++) {
scanf("%d", &a[i].data); //賦值
a[i].next = i + 1;
if (a[i].data > max) max=a[i].data;
}
head = 0;
a[n - 1].next = -1;

Output(a, head);
for (i=1; i<=max; i*=10) {
Distribute(a, i);
Out(a, i);
Collect(a);
Output(a, head);
}
}

『柒』 求c語言基數排序與桶排序的源代碼

基數排序:

#include<math.h>
testBS()
{
inta[]={2,343,342,1,123,43,4343,433,687,654,3};
int*a_p=a;
//計算數組長度
intsize=sizeof(a)/sizeof(int);
//基數排序
bucketSort3(a_p,size);
//列印排序後結果
inti;
for(i=0;i<size;i++)
{
printf("%d ",a[i]);
}
intt;
scanf("%d",t);
}
//基數排序
voidbucketSort3(int*p,intn)
{
//獲取數組中的最大數
intmaxNum=findMaxNum(p,n);
//獲取最大數的位數,次數也是再分配的次數。
intloopTimes=getLoopTimes(maxNum);
inti;
//對每一位進行桶分配
for(i=1;i<=loopTimes;i++)
{
sort2(p,n,i);
}
}
//獲取數字的位數
intgetLoopTimes(intnum)
{
intcount=1;
inttemp=num/10;
while(temp!=0)
{
count++;
temp=temp/10;
}
returncount;
}
//查詢數組中的最大數
intfindMaxNum(int*p,intn)
{
inti;
intmax=0;
for(i=0;i<n;i++)
{
if(*(p+i)>max)
{
max=*(p+i);
}
}
returnmax;
}
//將數字分配到各自的桶中,然後按照桶的順序輸出排序結果
voidsort2(int*p,intn,intloop)
{
//建立一組桶此處的20是預設的根據實際數情況修改
intbuckets[10][20]={};
//求桶的index的除數
//如798個位桶index=(798/1)%10=8
//十位桶index=(798/10)%10=9
//百位桶index=(798/100)%10=7
//tempNum為上式中的1、10、100
inttempNum=(int)pow(10,loop-1);
inti,j;
for(i=0;i<n;i++)
{
introw_index=(*(p+i)/tempNum)%10;
for(j=0;j<20;j++)
{
if(buckets[row_index][j]==NULL)
{
buckets[row_index][j]=*(p+i);
break;
}
}
}
//將桶中的數,倒回到原有數組中
intk=0;
for(i=0;i<10;i++)
{
for(j=0;j<20;j++)
{
if(buckets[i][j]!=NULL)
{
*(p+k)=buckets[i][j];
buckets[i][j]=NULL;
k++;
}
}
}
}

桶排序

#include<stdio.h>
#defineMAXNUM100

voidbucksort(intarr[],intN,intM)
{
intcount[MAXNUM];
for(inti=0;i<=M;i++)
{
count[i]=0;
}

for(inti=0;i<N;i++)
{
++count[arr[i]];
}

for(inti=0;i<=M;i++)
{
for(intj=1;j<=count[i];j++)
{
printf("%d",i);
}
}
}

intmain()
{
inta[]={2,5,6,12,4,8,8,6,7,8,8,10,7,6};
bucksort(a,sizeof(a)/sizeof(a[0]),12);
return0;
}

『捌』 一道C語言 數據結構 鏈表 求基數排序問題

假如不用基數列表,通過逐位藉助棧似乎也可以高效地得到結果(從「嵌套調用」改寫為「藉助棧」),但是不好理解。其實主要思路不復雜:隨機計算至少20個四位數,然後排序,可以用先除再求余數的方法,先得到高位數,把所有四位數分別整理到基數列表(最好可以同步記錄余數到列表項),此時就可以開始遍歷基數列表(從0到9,每個數所代表的列表對應一組「記錄了余數的對象」),對於每個子列表中的所有對象,逐個排列出來到原有數組空間(也就是refill),清理基數列表以便再次使用(記得在每次refill的時候,也需要clearlist,注意訪問的順序不能打亂,可以將上次從表尾加入的列表項找到,從表頭結點後清理);然後從數組空間里這些對象的余數找到其最高位數,即百位數,再次整理到基數列表,同步逐個排列出來到原有數組空間;以此類推,經過四輪處理就有結果了。

『玖』 基數排序是怎麼一回事(c語言)

基數排序的方式可以採用LSD(Least significant digital)或MSD(Most significant digital),LSD的排序方式由鍵值的最右邊開始,而MSD則相反,由鍵值的最左邊開始。
以LSD為例,假設原來有一串數值如下所示:
73, 22, 93, 43, 55, 14, 28, 65, 39, 81
首先根據個位數的數值,在走訪數值時將它們分配至編號0到9的桶子中:
0
1 81
2 22
3 73 93 43
4 14
5 55 65
6
7
8 28
9 39
接下來將這些桶子中的數值重新串接起來,成為以下的數列:
81, 22, 73, 93, 43, 14, 55, 65, 28, 39
接著再進行一次分配,這次是根據十位數來分配:
0
1 14
2 22 28
3 39
4 43
5 55
6 65
7 73
8 81
9 93
接下來將這些桶子中的數值重新串接起來,成為以下的數列:
14, 22, 28, 39, 43, 55, 65, 73, 81, 93
這時候整個數列已經排序完畢;如果排序的對象有三位數以上,則持續進行以上的動作直至最高位數為止。
LSD的基數排序適用於位數小的數列,如果位數多的話,使用MSD的效率會比較好,MSD的方式恰與LSD相反,是由高位數為基底開始進行分配,其他的演算方式則都是相同。

懂了沒?這是網路上的,還不懂的話再問我

『拾』 用c語言實現計數排序、基數排序、桶排序演算法。

網上找吧,這些都是基本東西,要不買本數據結構的書看看