数据结构实践—— 英文单词的基数排序

本文是针对[数据结构基础系列(9):排序]的实践。

【项目 - 英文单词的基数排序】
  设计一个基数排序的算法,将一组英文单词,按字典顺序排列。假设单词均由小写字母或空格构成,最长的单词有MaxLen个字母。

[参考解答]

#include <stdio.h>
#include <malloc.h>
#include <string.h>
#define MaxLen 9                //单词的最大长度
#define Radix  27               //基数rd为27,分别对应' ','a',…'z'
typedef char String[MaxLen+1];  //定义String为字符数组类型
typedef struct node
{
    String word;
    struct node *next;
} LinkNode;
void DispWord(String R[],int n) //输出单词
{
    int i;
    printf("  ");
    for (i=0; i<n; i++)
        printf("[%s] ",R[i]);
    printf("\n");
}
void PreProcess(String R[],int n)
//对单词进行预处理,用空格填充尾部至MaxLen长
{
    int i,j;
    for (i=0; i<n; i++)
    {
        if (strlen(R[i])<MaxLen)
        {
            for (j=strlen(R[i]); j<MaxLen; j++)
                R[i][j]=' ';
            R[i][j]='\0';
        }
    }
}
void EndProcess(String R[],int n)
//恢复处理,删除预处理时填充的尾部空格
{
    int i,j;
    for (i=0; i<n; i++)
    {
        for (j=MaxLen-1; R[i][j]==' '; j--);
        R[i][j+1]='\0';
    }
}
void Distribute(String R[],LinkNode *head[],LinkNode *tail[],int j,int n)
//按关键字的第j个分量进行分配,进入此过程时各队列一定为空
{
    int i,k;
    LinkNode *p;
    for (i=0; i<n; i++)         //依次扫描R[i],将其入队
    {
        if (R[i][j]==' ')       //空格时放入0号队列中,'a'时放入1号队列中,…
            k=0;
        else
            k=R[i][j]-'a'+1;
        p=(LinkNode *)malloc(sizeof(LinkNode)); //创建新结点
        strcpy(p->word,R[i]);
        p->next=NULL;
        if (head[k]==NULL)
        {
            head[k]=p;
            tail[k]=p;
        }
        else
        {
            tail[k]->next=p;
            tail[k]=p;
        }
    }
}
void Collect(String R[],LinkNode *head[])
//依次将各非空队列中的记录收集起来
{
    int k=0,i;
    LinkNode *p;
    for (i=0; i<Radix; i++)
        for (p=head[i]; p!=NULL; p=p->next)
            strcpy(R[k++],p->word);
}
void RadixSort(String R[],int n)    //对R[0..n-1]进行基数排序
{
    LinkNode *head[Radix],*tail[Radix]; //定义Radix个队列
    int i,j;
    for (i=MaxLen-1; i>=0; i--)             //从低位到高位做d趟箱排序
    {
        for (j=0; j<Radix; j++)
            head[j]=tail[j]=NULL;           //队列置空
        Distribute(R,head,tail,i,n);        //第i趟分配
        Collect(R,head);                    //第i趟收集
    }
}
int main()
{
    int n=6;
    String R[]= {"while","if","if else","do while","for","case"};
    printf("排序前:\n");
    DispWord(R,n);
    PreProcess(R,n);
    printf("预处理后:\n");
    DispWord(R,n);
    RadixSort(R,n);
    printf("排序结果:\n");
    DispWord(R,n);
    EndProcess(R,n);
    printf("最终结果:\n");
    DispWord(R,n);
    printf("\n");
    return 0;
}
时间: 2024-11-08 21:50:52

数据结构实践—— 英文单词的基数排序的相关文章

数据结构实践项目——排序

本文是[数据结构基础系列(9):排序]课程的实践项目. 本文针对: 1. 排序问题及导学 2. 插入排序之直接插入排序 3. 插入排序之希尔排序 4. 交换排序之冒泡排序 5. 交换排序之快速排序 6. 选择排序之直接选择排序 7. 选择排序之堆排序 8. 归并排序 9. 简单的计数排序 10. 基数排序 11. 各种排序的比较 纸上谈兵:"知原理"检验题目 1.给定序列{57, 40, 38, 11, 13, 34, 48, 75, 6, 19, 9, 7},采用下面的算法,分别描述

数据结构实践——大数据集上排序算法性能的体验

本文是针对[数据结构基础系列(9):排序]的实践项目. [项目 - 大数据集上排序算法性能的体验] 设计一个函数,产生一个至少5万条记录的数据集合.在同一数据集上,用直接插入排序.冒泡排序.快速排序.直接选择排序.堆排序.归并排序.基数排序等算法进行排序,记录所需要的时间,经过对比,得到对复杂度不同的各种算法在运行时间方面的感性认识. 提示1:这一项目需要整合多种排序算法,可以考虑先建设排序算法库,作为我们这门课算法库的收官之作: 提示2:本项目旨在获得对于复杂度不同算法的感性认识,由于数据分布

数据结构实践——停车场模拟(栈和队列综合)

本文是针对数据结构基础系列网络课程(3):栈和队列的实践项目. 设停车场是一个可停放n辆汽车的狭长死胡同,南边封口,汽车只能从北边进出(这样的停车场世间少有).汽车在停车场内按车辆到达时间的先后顺序,最先到达的第一辆车停放在车场的最南端,依次向北排开.若车场内已停满n辆汽车,则后来的汽车只能在门外的候车场上等候,一旦有车开走,则排在候车场上的第一辆车即可开入.当停车场内某辆车要离开时,在它之后进入的车辆必须先退出车场为它让路(假定停车场内设有供车辆进出的便道,所有的司机也必须在车内随时待命),待

数据结构实践项目——最短路径和拓扑序列

本文是针对[数据结构基础系列(7):图]的第2组实践例程. (程序中graph.h是图存储结构的"算法库"中的头文件,详情请单击链接-) 0710 生成树的概念 0711 最小生成树的普里姆算法 0712 最小生成树的克鲁斯卡尔算法 0713 从一个顶点到其余各顶点的最短路径 0714 每对顶点之间的最短路径 0715 拓扑排序 0716 AOE网与关键路径 纸上谈兵:"知原理"检验题目 1.针对下面的图1: (图1) (1)写出图的邻接矩阵: (2)按照Prim算

数据结构实践——单链表:逆置、连接与递增判断

本文针对数据结构基础系列网络课程(2):线性表的实践项目. [项目 - 单链表算法](程序中利用了已经实现的单链表算法,头文件LinkList.h及其中函数的实现见单链表算法库) 1.设计一个算法,将一个带头结点的数据域依次为a1,a2,-,an(n≥3)的单链表的所有结点逆置,即第一个结点的数据域变为an,-,最后一个结点的数据域为a1.实现这个算法,并完成测试. [参考解答] (程序中利用了已经实现的单链表算法,头文件LinkList.h及其中函数的实现见单链表算法库) #include <

数据结构实践项目——图的基本运算及遍历操作

本文是针对[数据结构基础系列(7):图]中第1-9课时的实践项目. 0701 图结构导学 0702 图的定义 0703 图的基本术语 0704 图的邻接矩阵存储结构及算法 0705 图的邻接表存储结构及算法 0706 图的遍历 0707 非连通图的遍历 0708 DFS的应用 0709 BFS的应用 [项目1 - 图基本算法库] 定义图的邻接矩阵和邻接表存储结构,实现其基本运算,并完成测试. 要求: 1.头文件graph.h中定义相关的数据结构并声明用于完成基本运算的函数.对应基本运算的函数包括

数据结构实践项目——查找(一)

本文是[数据结构基础系列(8):查找]课程的第一组实践项目. 本文针对: 0801 查找问题导学 0802 线性表的顺序查找 0803 线性表的折半查找 0804 索引存储结构 0805 分块查找 0806 二叉排序树 0807 二叉排序树(续) 0808 平衡二叉树 纸上谈兵:"知原理"检验题目 [参考(部分)] [参考(1)] 1.对于A[0..10]有序表{12,18,24,35,47,50,62,83,90,115,134} (1)用二分查找法查找 90时,需进行多少次查找可确

数据结构实践——猴子选大王

本文针对数据结构基础系列网络课程(2):线性表的实践项目. [项目 - 猴子选大王] 一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m的顺序围坐一圈.从第1只开始数,每数到第n个,该猴子就要离开此圈,这样依次下来,直到圈中只剩下最后一只猴子,则该猴子为大王.输入m和n,输出为大王的猴子是几号. 提示: (1)链表解法:可以用一个循环单链表来表示这一群猴子.表示结点的结构体中有两个成员:一个保存猴子的编号,一个为指向下一个人的指针,编号为m的结点再指向编号为1的结点,以此构成环形的链.

数据结构实践——猴子选大王(数组版)

本文针对数据结构基础系列网络课程(5): 数组与广义表的实践项目. [项目 - 猴子选大王(数组版)] 一群猴子,编号是1,2,3 -m,这群猴子(m个)按照1-m的顺序围坐一圈.从第1只开始数,每数到第n个,该猴子就要离开此圈,这样依次下来,最后一只出圈的猴子为大王.输入m和n,输出猴子离开圈子的顺序,从中也可以看出最后为大王是几号猴子. 要求采用数组作为存储结构完成. [参考解答1] 在一个数组中,数组中用1表示猴子在圈中,用0表示猴子已经出圈,数组下标对应与猴子编号对应(例如数组元素p[0