• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 数据结构 多关键字排序

数据结构 多关键字排序

作者: 字体:[增加 减小] 来源:互联网 时间:2017-12-31

通过本文主要向大家介绍了数据结构,多关键字排序等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

实验7 多关键字排序

一、实验目的 

    了解多关键字的使用范围;编写程序实现多关键字的排序。

二、实验原理

依次根据某位进行排序,排好序后更新a[i],最后得到的就是根据每位排好序的a[i]

    LSDSort()函数:cnt数组用来存放某位的个数,tmp数组存放a[i]数据,根据cnt[ ] 中的数据得到tmp中存放哪一个a[i]

三、参考程序

#include <stdio.h>
#include <stdlib.h>

#define RADIX 101 //基数,分数有 101 种可能 
#define K 3 //关键字,有 3 个关键字 

struct tagMark
{
int key[K]; //有 K 个关键字 
}a[8] = {{1,2,3}, {0,2,3}, {5,4,6}, {6,2,6}, {4,4,1}, {0,1,4},
{60,30,6}, {60,20,6}};

/*a:待排序的数组地址 
size:元素数量 
radix:基数 
k:关键字数量 
*/

void LSDSort(struct tagMark *a, int size, int radix, int k)
{
int *cnt = (int *)malloc(sizeof(int) * radix), i;
struct tagMark *tmp = (struct tagMark *)malloc(sizeof(struct tagMark) * size); //待排序的记录的数量 
while (k--)
{

//初始化cnt[i]
for (i = radix-1; i >= 0; --i)
cnt[i] = 0;

 

//计数
for (i = size; i > 0; )
++cnt[a[--i].key[k]];

//累加cnt
for (i = 0; i < radix; ++i)
cnt[i + 1] += cnt[i];

//按顺序把a[i]放入tmp中
for (i = size; i > 0; )
{
--i;
tmp[--cnt[a[i].key[k]]] = a[i];
}

//把a[i]按照某一位排好的序,重新排序
for (i = size; i > 0; )
{
--i;
a[i] = tmp[i];
}
}
free(cnt);
free(tmp);
}

int main()
{
int i, j;
LSDSort(a, 8, RADIX, K); //对 8 个记录进行排序

//输出 
for (i = 0; i < 8; ++i, putchar('\n'))
for (j = 0; j < K; ++j)
printf("%d ", a[i].key[j]);
return 0;
}

 

 

 

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 数据结构 多关键字排序
  • 数据结构 哈希表设计
  • 数据结构 最小生成树
  • 数据结构 数组顺序存储详细介绍
  • 数据结构之数组Array实例详解
  • C语言数据结构 栈的基础操作
  • C语言数据结构二叉树简单应用
  • C语言数据结构中串的模式匹配
  • 数据结构 C语言实现循环单链表的实例
  • 数据结构与算法中二叉树子结构的详解

相关文章

  • 2017-05-28深入理解C++中常见的关键字含义
  • 2022-04-30数据在内存中的存储(二进制形式存储)
  • 2022-04-30C语言自增(++)和自减(--)
  • 2017-05-28华为机试题之统计单词个数实例代码
  • 2017-05-28用c语言实现冒泡排序,选择排序,快速排序
  • 2017-05-28fatal error LNK1104: 无法打开文件“libc.lib”的解决方法
  • 2017-05-28头文件不宜定义变量的原因全面解析
  • 2017-05-28Python HTTP服务搭建显示本地文件
  • 2017-05-28如何判断一个数是否为4的幂次方?若是,并判断出来是多少次方?
  • 2017-05-28详解C语言中条件判断语句if和switch的用法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C语言设计图书登记系统与停车场管理系统的实例分享
    • C++求阶乘的两种方法
    • 简单谈谈C++ 头文件系列之(iosfwd)
    • C语言金币阵列问题解决方法
    • C++中overload,override,overwrite的区别详细解析
    • C语言实现杨辉三角实例
    • c++递归解数独方法示例
    • 用C语言模仿Python函数的一种简单实现方法
    • 基于C++中sprintf的错误总结详解
    • 浅谈C语言的字符串分割

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有