zoukankan      html  css  js  c++  java
  • _DataStructure_C_Impl:基数排序

    #include<stdio.h>
    #include<stdlib.h>
    #include<math.h>
    #include<string.h>
    #define MaxNumKey 6 /*keyword项数的最大值*/
    #define Radix 10	/*keyword基数,此时是十进制整数的基数*/
    #define MaxSize 1000
    #define N 6
    typedef int KeyType; /*定义keyword类型*/
    typedef struct
    {
    	KeyType key[MaxNumKey]; /*keyword*/
    	int next;
    }SListCell;	/*静态链表的结点类型*/
    
    typedef struct
    {
    	SListCell data[MaxSize];		/*存储元素,data[0]为头结点*/
    	int keynum;						/*每一个元素的当前keyword个数*/
    	int length;						/*静态链表的当前长度*/
    }SList;		/*静态链表类型*/
    typedef int addr[Radix]; /*指针数组类型*/
    
    typedef struct
    {
    	KeyType key; /* keyword项 */
    }DataType;
    
    void PrintList(SList L);
    void PrintList2(SList L);
    void InitList(SList *L,DataType d[],int n);
    int trans(char c);
    void Distribute(SListCell data[],int i,addr f,addr r);
    void Collect(SListCell data[],addr f,addr r);
    void RadixSort(SList *L);
    void InitList(SList *L,DataType a[],int n)
    	/* 初始化静态链表L(把数组D中的数据存于L中) */
    { 
    	char ch[MaxNumKey],ch2[MaxNumKey];
    	int i,j,max=a[0].key;
    	for(i=1;i<n;i++)					/*将最大的keyword存入max*/
    		if(max<a[i].key)
    			max=a[i].key;
    	(*L).keynum=(int)(log10((float)max))+1;	/*求keyword的个数*/
    	(*L).length=n;						/*待排序个数*/
    	for(i=1;i<=n;i++)
    	{
    		itoa(a[i-1].key,ch,10);					/*将整型转化为字符,并存入ch*/
    		for(j=strlen(ch);j<(*L).keynum;j++)		/*假设ch的长度<max的位数,则在ch前补'0'*/
    		{
    			strcpy(ch2,"0");
    			strcat(ch2,ch);
    			strcpy(ch,ch2);
    		}
    		for(j=0;j<(*L).keynum;j++)				/*将每一个keyword的各个位数存入key*/
    			(*L).data[i].key[j]=ch[(*L).keynum-1-j];
    	}
    	for(i=0;i<(*L).length;++i)				/*初始化静态链表*/
    		(*L).data[i].next=i+1;
    	(*L).data[(*L).length].next=0; 
    }
    
    int trans(char c)
    	/*将字符c转化为相应的整数*/
    { 
    	return c-'0';
    }
    void Distribute(SListCell data[],int i,addr f,addr r) 
    	/*为data中的第i个keywordkey[i]建立Radix个子表,使同一子表中元素的key[i]同样*/
    	/*f[0..Radix-1]和r[0..Radix-1]分别指向各个子表中第一个和最后一个元素*/
    { 
    	int j,p;
    	for(j=0;j<Radix;j++)				/*将各个子表初始化为空表*/
    		f[j]=0;							
    	for(p=data[0].next;p;p=data[p].next)
    	{
    		j=trans(data[p].key[i]);		/*将相应的keyword字符转化为整数类型*/
    		if(!f[j])						/*f[j]是空表。则f[j]指示第一个元素*/
    			f[j]=p;
    		else
    			data[r[j]].next=p;
    		r[j]=p;							/*将p所指的结点插入第j个子表中*/
    	}
    }
    
    
    
    void Collect(SListCell data[],addr f,addr r)
    	/*按key[i]将f[0..Radix-1]所指各子表依次链接成一个静态链表*/
    { 
    	int j,t;
    	for(j=0;!f[j];j++);	/*找第一个非空子表。succ为求后继函数*/
    	data[0].next=f[j];
    	t=r[j];				/*r[0].next指向第一个非空子表中第一个结点*/
    	while(j<Radix-1)
    	{
    		for(j=j+1;j<Radix-1&&!f[j];j++);	/*找下一个非空子表*/
    		if(f[j])							/*将非空链表连接在一起*/
    		{									
    			data[t].next=f[j];
    			t=r[j];
    		}
    	}
    	data[t].next=0;		/*t指向最后一个非空子表中的最后一个结点*/
    }
    
    void RadixSort(SList *L)
    	/*对L进行基数排序,使得L成为按keyword非递减的静态链表,L.r[0]为头结点*/
    { 
    	int i;
    	addr f,r;
    	for(i=0;i<(*L).keynum;i++)			/*由低位到高位依次对各keyword进行分配和收集*/
    	{				
    		Distribute((*L).data,i,f,r);	/*第i趟分配*/
    		Collect((*L).data,f,r);			/*第i趟收集*/
    		printf("第%d趟收集后:",i+1);
    		PrintList2(*L);
    	}
    }
    
    
    
    void main()
    {
    	DataType d[N]={268,126,63,730,587,184};
    	SList L;
    	InitList(&L,d,N);
    	printf("待排序元素个数是%d个,keyword个数为%d个
    ",L.length,L.keynum);
    	printf("排序前的元素:
    ");
    	PrintList2(L);
    	printf("排序前的元素的存放位置:
    ");
    	PrintList(L);
    	RadixSort(&L);
    	printf("排序后元素的存放位置:
    ");
    	PrintList(L);
    	system("pause");
    }
    void PrintList(SList L)
    	/*按数组序号形式输出静态链表*/
    { 
    	int i,j;
    	printf("序号 keyword 地址
    ");
    	for(i=1;i<=L.length;i++)
    	{
    		printf("%2d    ",i);
    		for(j=L.keynum-1;j>=0;j--)
    			printf("%c",L.data[i].key[j]);
    		printf("    %d
    ",L.data[i].next);
    	}
    }
    void PrintList2(SList L)
    	/*按链表形式输出静态链表*/
    {
    	int i=L.data[0].next,j;
    	while(i)
    	{
    		for(j=L.keynum-1;j>=0;j--)
    			printf("%c",L.data[i].key[j]);
    		printf(" ");
    		i=L.data[i].next;
    	}
    	printf("
    ");
    }

  • 相关阅读:
    微博三方登录流程
    完善注册接口
    vue检查用户名是否重复
    转载:TypeError: Cannot read property 'compilation' of undefined vue 打包运行npm run build 报错
    转载:mybatis中<![CDATA[]]>的作用
    转载:eclipse中web项目小地球没了
    转载:解决npm安装时出现run `npm audit fix` to fix them, or `npm audit` for details
    转载:IDEA lombok插件的安装和使用
    转载:idea配置svn及使用
    RESTful风格编程
  • 原文地址:https://www.cnblogs.com/yxysuanfa/p/7098464.html
Copyright © 2011-2022 走看看