2015-12-18 第十六周 项目4 - 英文单词的基数排序

2024-02-26 17:18

本文主要是介绍2015-12-18 第十六周 项目4 - 英文单词的基数排序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.问题及代码

#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;  
}  


2.运行结果


3.知识总结

  利用排序知识对英文单词进行排序

4.学习心得


这篇关于2015-12-18 第十六周 项目4 - 英文单词的基数排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/749584

相关文章

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

《SpringBoot项目使用MDC给日志增加唯一标识的实现步骤》本文介绍了如何在SpringBoot项目中使用MDC(MappedDiagnosticContext)为日志增加唯一标识,以便于日... 目录【Java】SpringBoot项目使用MDC给日志增加唯一标识,方便日志追踪1.日志效果2.实现步

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法

《SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法》本文主要介绍了SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录方法1:更改IDE配置方法2:在Eclipse中清理项目方法3:使用Maven命令行在开发Sprin

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

《SpringBoot项目注入traceId追踪整个请求的日志链路(过程详解)》本文介绍了如何在单体SpringBoot项目中通过手动实现过滤器或拦截器来注入traceId,以追踪整个请求的日志链... SpringBoot项目注入 traceId 来追踪整个请求的日志链路,有了 traceId, 我们在排