- 热门文章:
- · 浮点指令的优化
- · 在应用程序中集成自动完成功能
- · windows系统换服程序探讨
- · 数据结构学习(C++)续——排序【2】插入排序
- · 数据访问接口体系及数据对象模型探讨--[3]
- · 文档自动生成系统的研究与开发
- · DLL中类的显式链接
- · VC雕虫小技集(一)
- · VC雕虫小技集(二)
- · VC雕虫小技集(三)
- · VC雕虫小技集(四)
- · VC雕虫小技集(五)
数据结构学习(C++)续——排序【1】测试程序
后面的例程,都是对数组的排序,使用静态链表的也适用于链表的排序。为简单起见,只对单关键码排序,并且最后的结果都是从头到尾按升序排列。下面是统一的测试程序:
#include <iostream>
#include <iomanip>
using namespace std;
#include <stdlib.h>
#include <time.h>
#include <math.h>
#include "InsertSort.h"
#define random(num) (rand() % (num))
#define randomize() srand((unsigned)time(NULL))
#define N 10000 //排序元素的数目
#define SORT InsertSort //排序方法
class timer//单位ms
{
public:
void start() { start_t = clock(); }
clock_t time() { return (clock() - start_t); }
private:
clock_t start_t;
};
int KCN, RMN; timer TIMER;
void test(int a[])
{
TIMER.start();
SORT<int>(a, N, KCN, RMN);
cout << "\tTimeSpared: " << TIMER.time() << "ms" << endl;
cout << "KCN=" << left << setw(11) << KCN;
cout << "KCN/N=" << left << setw(11)<< (double)KCN/N;
cout << "KCN/N^2=" << left << setw(11)<< (double)KCN/N/N;
cout << "KCN/NlogN=" << left << setw(11)<< (double)KCN/N/log((double)N)*log(2.0) << endl;
cout << "RMN=" << left << setw(11) << RMN;
cout << "RMN/N=" << left << setw(11)<< (double)RMN/N;
cout << "RMN/N^2=" << left << setw(11)<< (double)RMN/N/N;
cout << "RMN/NlogN=" << left << setw(11)<< (double)RMN/N/log((double)N)*log(2.0) << endl;
}
int main()
{
int i;
//randomize();为了在相同情况下比较各个排序算法,不加这句
int* ascending = new int[N];//升序序列
int* descending = new int[N];//降序序列
int* randomness = new int[N];//随机序列
for (i = 0; i < N; i++) { ascending[i] = i; randomness[i] = i; descending[i] = N - i - 1;}
for (i = 0; i < N; i++) swap(randomness[i], randomness[random(N)]);
cout << "Sort ascending N=" << N; test(ascending);
cout << "Sort randomness N=" << N; test(randomness);
cout << "Sort descending N=" << N; test(descending);
return 0;
}
需要说明一点,KCN(关键码比较次数)、RMN(记录移动次数)并不是算法必须的,是为了对算法的性能有个直观的评价(不用那些公式算来算去)。对10000个整数排序应该是最省事的测试手段,建议不要再增多记录数目了,一是在最坏的情况不用等太久的时间,二是避免KCN、RMN溢出,另外有些递归的算法在情况比较糟的时候,记录数目太多堆栈可能会溢出,导致程序崩溃。
- · VC雕虫小技集(六)
- · VC雕虫小技集(七)
- · 编程语言的异同及选择
- · 流媒体学习笔记----配置一个编码进程
- · 流媒体学习笔记---------编码视频的预览
- · 在VC中动态改变菜单
- · VC++ ADO开发实践之一
- · VC++ ADO开发实践之二
- · VC++ ADO开发实践之三
- · VC++ ADO开发实践之四
- · VC++ ADO开发实践之五
- · VC++ ADO开发实践之六
- · VC++ ADO开发实践之七
- · 图像平滑滚动效果的VC实现
- · VC中给树形控件的图标加上工具提示
- · VC++实现拨号上网程序
- · C++关键字(static/register/atuo/extern/volatile/const)释疑
- · .Net中的反射使用入门
- · 站在面相对象角度小议C++
- · Learn c++ step by step
- · Learn C++ step by step(2)
- · C++中的文件输入/输出(6):一些有用的函数
- · 如何在自己的程序中加入宏的功能
- · 在应用程序中将OJB作为一个存储层使用(一)
- · 在应用程序中将OJB作为一个存储层使用(五)
- · 数据结构学习(C++)续——排序【3】交换排序
- · 也用 C++ 实现 Property 功能
- · 获取网页中的密码和文本输入框的内容
- · 提取网页所有链接
- · 平台+插件软件设计思想及基于COM的原型实现
- · 编写驱动拦截NT的API实现隐藏文件目录
- · 用Visual C++编写电子邮件程序
- · VC实现屏幕变暗效果
- · InstallShield6.3安装文件制作要点
- · GeoTiff探索成果总结
- · MapObject控件的使用之加入图层
- · 学好VC++的十大良好习惯
- · MapObject控件的使用之图层操作
