[算法] O(nlogn)和O(n^2)算法性能比较
选择排序、插入排序、归并排序
main.cpp
1 #include <iostream>
2 #include "Student.h"
3 #include "SortTestHelper.h"
4
5 using namespace std;
6
7 template<typename T>
8 void selectionSort(T arr[],int n){
9 for(int i = 0 ; i < n ; i ++){
10 int minIndex = i;
11 for( int j = i + 1 ; j < n ; j ++ )
12 if( arr[j] < arr[minIndex] )
13 minIndex = j;
14 swap( arr[i] , arr[minIndex] );
15 }
16 }
17
18 template<typename T>
19 void insertionSort(T arr[],int n){
20 for(int i = 1 ; i < n ; i++ ){
21 T e = arr[i];
22 int j;
23 for(j = i ; j > 0 && arr[j-1] > e ; j --)
24 arr[j] = arr[j-1];
25 arr[j] = e;
26 }
27 }
28
29 template<typename T>
30 // 将arr[l...mid]和arr[mid+1...r]两部分进行归并
31 void __merge(T arr[] , int l, int mid, int r){
32 T aux[r-l+1];
33 // 将数组复制一份到aux[]
34 for( int i = l ; i <= r ; i ++ )
35 aux[i-l] = arr[i];
36 // 初始化,i、j指向左、右半部分的起始索引位置
37 int i = l, j = mid + 1;
38 for( int k = l ; k <= r ; k ++ ){
39 // 如果左半部分已处理完毕
40 if( i > mid){
41 arr[k] = aux[j-l];
42 j++;
43 }
44 // 如果右半部分已处理完毕
45 else if( j > r){
46 arr[k] = aux[i-l];
47 i ++;
48 }
49 // 左半部分所指元素 < 右半部分所指元素
50 else if( aux[i-l] < aux[j-l] ){
51 arr[k] = aux[i-l];
52 i ++;
53 }
54 // 左半部分所指元素 >= 右半部分所指元素
55 else{
56 arr[k] = aux[j-l];
57 j++;
58 }
59 }
60 }
61
62 // 递归使用归并排序,对arr[l...r]的范围进行排序
63 template<typename T>
64 void __mergeSort(T arr[] , int l, int r){
65
66 if( l >= r)
67 return;
68
69 int mid = (l+r)/2;
70 __mergeSort(arr,l,mid);
71 __mergeSort(arr,mid+1,r);
72 __merge(arr, l, mid, r);
73 }
74
75 template<typename T>
76 void mergeSort(T arr[] , int n){
77 __mergeSort( arr , 0 , n-1 );
78 }
79
80 int main(){
81 int n = 10000;
82 //int *arr = SortTestHelper::generateNearlyOrderedArray(n,10);
83 int *arr1 = SortTestHelper::generateRandomArray(n,0,n);
84 int *arr2 = SortTestHelper::copyIntArray(arr1, n);
85 SortTestHelper::testSort("Insertion Sort",insertionSort,arr1,n);
86 SortTestHelper::testSort("Merge Sort",mergeSort,arr2,n);
87
88 delete[] arr1;
89 delete[] arr2;
90
91 return 0;
92 }
SortTestHelper.h
1 #include <iostream>
2 #include <ctime>
3 #include <cassert>
4 #include <string>
5
6 using namespace std;
7
8 namespace SortTestHelper{
9 // 生成随机数组
10 int *generateRandomArray(int n,int rangeL,int rangeR){
11 assert(rangeL <= rangeR);
12 int *arr = new int[n];
13 srand(time(NULL));
14 for(int i = 0 ; i < n ; i++)
15 arr[i] = rand()%(rangeR-rangeL+1) + rangeL;
16 return arr;
17 }
18 // 生成近似有序数组
19 int *generateNearlyOrderedArray(int n, int swapTimes){
20 int *arr = new int[n];
21 for(int i = 0 ; i < n ; i ++ )
22 arr[i] = i;
23 srand(time(NULL));
24 for( int i = 0 ; i < swapTimes ; i ++){
25 int posx = rand()%n;
26 int posy = rand()%n;
27 swap( arr[posx] , arr[posy] );
28 }
29 return arr;
30 }
31
32 // 拷贝整型数组a中所有元素到新数组并返回
33 int *copyIntArray(int a[], int n){
34 int *arr = new int[n];
35 copy(a, a+n, arr);
36 return arr;
37 }
38
39 // 打印arr数组的所有内容
40 template<typename T>
41 void printArray(T arr[],int n){
42 for(int i = 0;i<n;i++)
43 cout << arr[i] <<" ";
44 cout << endl;
45 return;
46 }
47
48 // 判断arr数组是否有序
49 template<typename T>
50 bool isSorted(T arr[],int n){
51 for(int i = 0 ; i<n-1 ; i++)
52 if(arr[i] > arr[i+1])
53 return false;
54 return true;
55 }
56
57 // 测试sort排序算法排序arr数组所得结果的正确性和算法运行时间
58 template<typename T>
59 void testSort(const string &sortName,void (*sort)(T[],int),T arr[],int n){
60
61 clock_t startTime = clock();
62 sort(arr,n);
63 clock_t endTime = clock();
64
65 assert(isSorted(arr,n));
66
67 cout << sortName << " : " << double(endTime-startTime)/CLOCKS_PER_SEC << " s" <<endl;
68
69 return;
70 }
71 }
运行结果:
Merge Sort可在1s内轻松处理100万数量级的数据
[算法] O(nlogn)和O(n^2)算法性能比较的更多相关文章
- java算法03 - 常用的8种排序算法
Java常用的八种排序算法: 插入排序 - 直接插入排序 每次将待排序的记录按照关键字的大小,插入到前面已经排好序的记录的适当位置.直到全部记录插入完成. 代码实现 /** * 直接插入排序 O(n^ ...
- JavaScript 数据结构与算法之美 - 十大经典排序算法汇总(图文并茂)
1. 前言 算法为王. 想学好前端,先练好内功,内功不行,就算招式练的再花哨,终究成不了高手:只有内功深厚者,前端之路才会走得更远. 笔者写的 JavaScript 数据结构与算法之美 系列用的语言是 ...
- EM算法(2):GMM训练算法
目录 EM算法(1):K-means 算法 EM算法(2):GMM训练算法 EM算法(3):EM算法运用 EM算法(4):EM算法证明 EM算法(2):GMM训练算法 1. 简介 GMM模型全称为Ga ...
- 推荐一个算法编程学习中文社区-51NOD【算法分级,支持多语言,可在线编译】
最近偶尔发现一个算法编程学习的论坛,刚开始有点好奇,也只是注册了一下.最近有时间好好研究了一下,的确非常赞,所以推荐给大家.功能和介绍看下面介绍吧.首页的标题很给劲,很纯粹的Coding社区....虽 ...
- 70 数组的Kmin算法和二叉搜索树的Kmin算法对比
[本文链接] http://www.cnblogs.com/hellogiser/p/kmin-of-array-vs-kmin-of-bst.html [分析] 数组的Kmin算法和二叉搜索树的Km ...
- 《算法导论》读书笔记之图论算法—Dijkstra 算法求最短路径
自从打ACM以来也算是用Dijkstra算法来求最短路径了好久,现在就写一篇博客来介绍一下这个算法吧 :) Dijkstra(迪杰斯特拉)算法是典型的最短路径路由算法,用于计算一个节点到其他所有节点的 ...
- 字符串查找算法总结(暴力匹配、KMP 算法、Boyer-Moore 算法和 Sunday 算法)
字符串匹配是字符串的一种基本操作:给定一个长度为 M 的文本和一个长度为 N 的模式串,在文本中找到一个和该模式相符的子字符串,并返回该字字符串在文本中的位置. KMP 算法,全称是 Knuth-Mo ...
- 《算法4》2.1 - 选择排序算法(Selection Sort), Python实现
选择排序算法(Selection Sort)是排序算法的一种初级算法.虽然比较简单,但是基础,理解了有助于后面学习更高深算法,勿以勿小而不为. 排序算法的语言描述: 给定一组物体,根据他们的某种可量化 ...
- 经典算法研究系列:二、Dijkstra 算法初探
July 二零一一年一月 本文主要参考:算法导论 第二版.维基百科. 一.Dijkstra 算法的介绍 Dijkstra 算法,又叫迪科斯彻算法(Dijkstra),算法解决的是有向图中单个源点到 ...
随机推荐
- CMS前世今生
CMS一直是面试中的常考点,今天我们用通俗易懂的语言简单介绍下. 垃圾回收器为什么要分区分代? 如上图:JVM虚拟机将堆内存区域分代了,先生代是朝生夕死的区域,老年代是老不死的区域,不同的年代对象有不 ...
- 消息中间件rabbitMQ
1 为什么使用消息队列啊? 其实就是问问你消息队列都有哪些使用场景,然后你项目里具体是什么场景,说说你在这个场景里用消息队列是什么 面试官问你这个问题,期望的一个回答是说,你们公司有个什么业务场景,这 ...
- 【CTF】CTFHub 技能树 彩蛋 writeup
碎碎念 CTFHub:https://www.ctfhub.com/ 笔者入门CTF时时刚开始刷的是bugku的旧平台,后来才有了CTFHub. 感觉不论是网页UI设计,还是题目质量,赛事跟踪,工具软 ...
- 自动化kolla-ansible部署ubuntu20.04+openstack-victoria之vmware设置-02
自动化kolla-ansible部署ubuntu20.04+openstack-victoria之vmware设置-02 欢迎加QQ群:1026880196 进行讨论 1. vmwae版本 2. 网 ...
- Java性能优化的十条小技巧
1 System.nanoTime 测试性能时,System.nanoTime比System.currentTimeMills更精确,前者使用纳秒计时,且对系统影响更小. 具体来说: System.c ...
- (二) LDAP 安装
LDAP 安装 参考:https://blog.51cto.com/bigboss/2341986
- Python的文本和字节序列
一.字符串的表示和存储 字符串是字符的序列,每个字符都有有一个数字作为标识,同时会有一个将标识转换为存储字节的编码方案: s = 'hello world python' for c in s: pr ...
- 面试有关TCP常问的几个问题
在面试中网络问题是一定会考察的,而TCP协议则是考察网络知识的重点.经常会被问道的问题如下: 请讲一下TCP协议建立连接的过程 请介绍TCP协议中的三次握手和四次挥手是怎么样的 为什么TCP协议要三次 ...
- AdaBoostClassifier参数
[AdaBoostClassifier] Adaboost-参数: base_estimator:基分类器,默认是决策树,在该分类器基础上进行boosting,理论上可以是任意一个分类器,但是如果是其 ...
- 07- Linux常用命令
cat命令 作用:将文件内容作为标准输出打印到终端. 格式:cat 文件名1 文件名2 例如: cat more命令: 作用:分页显示文本文件的内容 格式:more 文件名 实例:more he ...