闲着没事,想思考一下两种排序法的直观对比,写了个小程序,代码如下,分析见后面:

  

class Program
{
static DateTime t1, t2;
static TimeSpan ts1, ts2,ts3;
static int c1 = 0, c2 = 0,c3=0;
static void quick_sort(int[] a, int start, int end)
{
int key, i, j, dir = -1;
if (end <= start)
{
return;
}
i = start;
key = a[i];
j = end + 1;
while (i < j)
{
c1++;
if (dir == -1)
{
if (a[--j] < key)
{
a[i] = a[j];
dir = 1;
}
}
else
{
if (a[++i] > key)
{
a[j] = a[i];
dir = -1;
}
}
}
a[i] = key;
quick_sort(a, start, i - 1);
quick_sort(a, i + 1, end);
}
static void bubble_sort0(int[] a, int start)
{
int t;
if (start == a.Length - 1)
{
return;
}
for (int i = a.Length - 1; i >= start + 1; i--)
{
c2++;
if (a[i - 1] > a[i])
{
t = a[i - 1];
a[i - 1] = a[i];
a[i] = t;
}
}
bubble_sort0(a, start + 1);
}
static void bubble_sort1(int[] a)
{
int t;
for (int j = 1; j <= a.Length - 1; j++)
{
for (int i = a.Length - 1; i >= j; i--)
{
c3++;
if (a[i - 1] > a[i])
{
t = a[i - 1];
a[i - 1] = a[i];
a[i] = t;
}
}
}
}
static void Main(string[] args)
{
int[] a, b,c;
int length = 2500;
a = new int[length * 3];
//init array
for (int index = 0, i = 1, j = length + 1, k = length * 2 + 1; i <= length; i++, j++, k++)
{
a[index++] = i;
a[index++] = j;
a[index++] = k;
}
a.Reverse();
b = new int[a.Length];
c = new int[a.Length];
a.CopyTo(b, 0);
a.CopyTo(c, 0); //bubble_sort0 start
t1 = DateTime.Now;
bubble_sort0(b, 0);
t2 = DateTime.Now;
ts2 = t2.Subtract(t1); //quick_sort start
t1 = DateTime.Now;
quick_sort(a, 0, a.Length - 1);
t2 = DateTime.Now;
ts1 = t2.Subtract(t1); //bubble_sort1 start
t1 = DateTime.Now;
bubble_sort1(b);
t2 = DateTime.Now;
ts3 = t2.Subtract(t1); //output array
////Console.WriteLine("Array a:");
////foreach (var item in a)
////{
//// Console.Write(item + " ");
////}
////Console.WriteLine();
////Console.ReadKey();
////Console.WriteLine("Array b:");
////foreach (var item in b)
////{
//// Console.Write(item + " ");
////}
////Console.WriteLine();
////Console.ReadKey();
Console.WriteLine($"Quick_sort spends {ts1.Milliseconds} ms.count={c1}");
Console.WriteLine($"Bubble_sort0 spends {ts2.Milliseconds} ms.count={c2}");
Console.WriteLine($"Bubble_sort1 spends {ts3.Milliseconds} ms.count={c3}");
Console.ReadKey();
}
}

  

运行结果如图:

想要看到更悬殊的差距,自行调大“int length =2500;”的值就可以了。

简单地分析:

1、冒泡法对n个数排序,第一次比较n-1个,第二次比较n-2个,第三次比较n-3个。。。。以此类推。

2、快排对n个数排序,第一次比较n-1(分界数0,参照数1)个,第二次比较n-3(分界数1,参照数2)个,第三次比较n-7(分界数3,参照数4)个,第四次比较n-15(分界数7,参照数8)。。。。以此类推

(每次比较都会去掉分界点的那个数字和每组中的一个数字,而组数是按2的n次方增加的)

3、bubble_sort0和bubble_sort1是递归与否的差别。可以看出递归会消耗一点时间。事实上,递归也很耗空间。

仅考虑比较多次数,快排完胜。

冒泡排序法vs快速排序法的更多相关文章

  1. php排序介绍_冒泡排序_选择排序法_插入排序法_快速排序法

    这里我们介绍一些常用的排序方法,排序是一个程序员的基本功,所谓排序就是对一组数据,按照某个顺序排列的过程. 充效率看 冒泡排序法<选择排序法<插入排序法 排序分两大类: 内部排序法 交换式 ...

  2. Java演算法之快速排序法

    1 * 快速排序法(Quick Sort),遞迴版本. 2 * 3 * @param array 傳入要排序的陣列 4 * @param start 傳入要排序的開始位置 5 * @param end ...

  3. php四种基础算法:冒泡,选择,插入和快速排序法

    转自:http://www.php100.com/html/php/rumen/2013/1029/6333.html 许多人都说 算法是程序的核心,一个程序的好于差,关键是这个程序算法的优劣.作为一 ...

  4. php四种基础算法:冒泡,选择,插入和快速排序法PHP基础教程

    许多人都说 算法是程序的核心,一个程序的好于差,关键是这个程序算法的优劣.作为一个初级phper,虽然很少接触到算法方面的东西.但是对于冒泡排序,插入排序,选择排序,快速排序四种基本算法,我想还是要掌 ...

  5. c/c++ 算法之快速排序法 冒泡排序法,选择排序法,插入排序法

    本文详细叙述和实现了快速排序算法,冒泡排序 选择排序 插入排序比较简单,原理在这里不再详述,直接用代码进行了实现. 快速排序法(quicksort)是目前所公认最快的排序方法之一(视解题的对象而定), ...

  6. Java 快速排序法 冒泡排序法 选择排序法 插入排序法

    1.快速排序的原理: 选择一个关键值作为基准值.比基准值小的都在左边序列(一般是无序的),比基准值大的都在右边(一般是无序的). 从后往前比较,用基准值和最后一个值比较,如果比基准值小的交换位置,如果 ...

  7. PHP两种基础的算法:冒泡、快速排序法》》》望能够帮助到大家

    首先扯个淡@@@@@@@@@ 算法是程序的核心,一个程序的好坏关键是这个程序算法的优劣. 冒泡排序法 原理:在要排序的一组数中,对当前还未排好的序列,从前往后对相邻的两个数依次进行比较和调整,让较大的 ...

  8. v8--sort 方法 源码 (2) 快速排序法

    v8 sort方法部分关于快速排序法的源码: function QuickSort(a, from, to) { // Insertion sort is faster for short array ...

  9. javascript的快速排序法

    在排序方式中,快速是比较普遍使用的,因为其速度快. 因为其是不断的递归,而且是根据基准点的左右两边开始递归,直到数组只有一个值的时候才返回. 这个基准点是自己定的. 一般取中间,比较好理解. < ...

随机推荐

  1. MySQL数据备份概述

    MySQL备份类型 热备份.温备份.冷备份 (根据服务器状态) 热备份:读.写不受影响: 温备份:仅可以执行读操作: 冷备份:离线备份:读.写操作均中止: 物理备份与逻辑备份 (从对象来分) 物理备份 ...

  2. 解决Mac下SourceTree每次都让输入密码的问题

    在Mac上操作sourcetree当pull和push时每次都是让输入密码,非常烦人,虽然大概知道是因为SSH什么的问题,但搜索百度也没发现解决办法. 于是乎搜索谷歌,发现如下解决办法. Source ...

  3. 【Servlet】The servlets named [ByteServlet] and [content.ByteServlet] are both mapped to the url-pattern [ByteServlet] which is not permitted

    创建时间:6.30 The servlets named [ByteServlet] and [content.ByteServlet] are both mapped to the url-patt ...

  4. Caused by: java.lang.ClassNotFoundException: Cannot find class:

    Caused by: org.apache.ibatis.builder.BuilderException: Error resolving class. Cause: org.apache.ibat ...

  5. KVM虚拟机嵌套虚拟化

    KVM虚拟机嵌套虚拟化 背景介绍 ​ 在Arch linux的 KVM 虚拟机上启动来部署开源Iaas系统zstack时,需要开启虚拟机嵌套虚拟化. 解决 ​ KVM 嵌套式虚拟 Nested 是一个 ...

  6. LeetCode 825. Friends Of Appropriate Ages

    原题链接在这里:https://leetcode.com/problems/friends-of-appropriate-ages/ 题目: Some people will make friend ...

  7. prototype、__proto__、constructor

    prototype:每个函数都有一个prototype属性,这个属性指向一个对象,这个对象叫原型对象. 作用:节约内存.扩展属性和方法.可以实现类之间的继承 __proto__:每个通过构造函数new ...

  8. Seminar Schedule

    Seminar Schedule (C2017 | 2019.9-12 | 3rd semester S0500783) *************************************** ...

  9. shell中使用expect命令进行远程执行命令脚本

    expect是用来实现自动交互功能的工具之一,使用expect-send来实现交互过程. 注意: 1.脚本的执行方法与bash shell不一样,比如:expect example.sh 2.向一个脚 ...

  10. [Gamma]Scrum Meeting#10

    github 本次会议项目由PM召开,时间为6月5日晚上10点30分 时长15分钟 任务表格 人员 昨日工作 下一步工作 木鬼 撰写博客,组织例会 撰写博客,组织例会 swoip 前端显示屏幕,翻译坐 ...