问答题 有一种简单的排序算法,叫做计数排序(CountSorting)。这种排序算法对一个待排序的表(用数组表示)进行排序,并将排序结果存放到另一个新的表中。必须注意的是,表中所有待排序的关键码互不相同,计数排序算法针对表中的每个记录,扫描待排序的表一趟,统计表中有多少个记录的关键码比该记录的关键码小,假设针对某一个记录,统计出的计数值为c,那么,这个记录在新的有序表中的合适的存放位置即为C。
问答题 给出适用于计数排序的数据表定义。
【正确答案】正确答案:定义数据结构如下: typedef Struct{ int keY; datatype info; )RecType;
【答案解析】
问答题 使用C语言编写实现计数排序的算法。
【正确答案】正确答案:算法的基本设计思想:对每个元素,统计关键字比它小的元素个数,然后把它放入到另一个数组中。算法的代码: void CountSort(RecType a[],RecType b[],int n){ //计数排序算法,将a中记录排序放入b中 int i,j; int cnt; for(i=0;i
【答案解析】
问答题 对于有n个记录的表,关键码比较次数是多少?
【正确答案】正确答案:对于有n个记录的表,关键码比较n 2 次。
【答案解析】
问答题 与简单选择排序相比较,这种方法是否更好?为什么?【清华大学2000年】
【正确答案】正确答案:简单选择排序算法比本算法好。简单选择排序比较次数为n(n一)/2,且只用一个交换记录的空间:而这种方法比较次数为n 2 ,且需要另一数组空间。另外,因题目要求“针对表中的每个记录,扫描待排序的表一趟”,所以比较次数为n 2 。若限制"对任意两个记录之间应只进行一次比较",则可把以上算法中的比较语句改为: for(i=0; i
【答案解析】