一、原理解析

快速排序法:

基本思路是,从第一个元素开始,把所有比它大的元素放在它后面,把所有比它小的元素放前面。然后划分它前面和后面的所有元素,分别再做快速排序,直到无法再划分为止。

在以下程序案例中我们使用非递归的方式,并借助栈的数据结构实现。(关于栈的基本介绍,请看上一篇:http://www.cnblogs.com/HongYi-Liang/p/7766684.html


二、程序解析

C语言版本:

源码:

bool bAirob_QuickSort_int16(int16_t *src,int len) //int16_t
{
int i ;
int j ;
int head;
int tail;
MyStack stack={}; Stack_Init(&stack,*len);
Stack_push(&stack,len-);
Stack_push(&stack,); while(Stack_size(&stack))
{
Stack_top(&stack,&head);
Stack_pop(&stack);
Stack_top(&stack,&tail);
Stack_pop(&stack); i=head;
j=tail; while(i<j)
{
while(j>i && src[j]>=src[i])
{
--j;
}
Swap(&src[i],&src[j]); while(i<j && src[i]<=src[j])
{
++i;
}
Swap(&src[i],&src[j]);
}
if(i!=tail)
{
Stack_push(&stack,tail);
Stack_push(&stack,i+);
}
if(i!=head )
{
Stack_push(&stack,i-);
Stack_push(&stack,head);
}
} Stack_Delete(&stack);
return true;
}
void Swap(int16_t *a,int16_t *b)
{
int c=*a;
*a=*b;
*b=c;
}

结果 :

测试程序

#define BUFFSIZE 8
int16_t testbuff[BUFFSIZE] = {,,,,,,,};
int main()
{
int i;
bAirob_QuickSort_int16(testbuff,BUFFSIZE);
for(i=;i<BUFFSIZE;i++)
{
printf("%d ",testbuff[i]);
}
printf("\r\n"); system("pause");
return ;
}

解析:

  1. 首先声明了一个栈结构stack用于储存还还没排序完成的段落。
  2. 先把数组头索引和尾索引压入栈中。
  3. 从栈中把取出两个数数据,第一个作为头索引,第二个作为尾索引。
  4. 以数组头索引的数据为分界把所有小于它的数放在前面,大于它的数放在后面后面。具体做法是while(i<j){}中的一段,最后i,j会重合。
  5. 如果前半部分仍能继续分组( i!=head),则把头索引和i的前一个元素索引压入栈中。如果后半部分仍能继续分组(j!=tail),则把i的下一个元素的索引和尾索引压入栈中。(压栈时先压大的索引再压小的索引)
  6. 循环上面3-5步,直到栈为空。

用上面程序为例子

原始数组:{7,1,6,2,3,5,0,4}

第一次循环时,所有小于7的数放到了左边,大于7的数放到了左边。变成这样{4,1,6,2,3,5,0,7}

第二次循环,对{4,1,6,2,3,5,0,7},对黄色部分操作,所有大于4的数在右边,小于4的数在左边{0,1,3,2,4,5,6,7}。这时候压入栈中有两组数据,4左边一组,4右边一组。

第三次循环,对{0,1,3,2,4,5,6,7}进行操作,0作为最小的数已经在最左边了,所以数组不变。

第四次循环,{0,1,3,2,4,5,6,7},对132操作,同上1是最小且在最左边了,所以不会改变。

第五次循环,{0,1,3,2,4,5,6,7},对32操作,两个数调换了位置{0,1,2,3,4,5,6,7}。到这一部,4的左边已经全部处理完了,接下栈中剩下一组数据,4的右边。

第六次循环{0,1,2,3,4,5,6,7},对56操作,然而他们本身就好了,到这里为止,排序结束。

现在我们再看一次动图(因为动图设置没有数据“0”就用另一个“1”来代替)

数据结构-栈(应用篇)之快速排序法-C和C++的实现的更多相关文章

  1. javascript数据结构与算法--高级排序算法(快速排序法,希尔排序法)

    javascript数据结构与算法--高级排序算法(快速排序法,希尔排序法) 一.快速排序算法 /* * 这个函数首先检查数组的长度是否为0.如果是,那么这个数组就不需要任何排序,函数直接返回. * ...

  2. JS数据结构第四篇 --- 栈

    一.什么是数据结构栈 在数据结构中有一个栈结构,在内存空间中也有一个栈空间,这两个”栈“是两个不同的概念.这篇我们说的是数据结构中的栈.栈是一种特殊的线性表,特殊性在哪?就是只能在栈顶进行操作,往栈顶 ...

  3. 数据结构和算法(Golang实现)(14)常见数据结构-栈和队列

    栈和队列 一.栈 Stack 和队列 Queue 我们日常生活中,都需要将物品排列,或者安排事情的先后顺序.更通俗地讲,我们买东西时,人太多的情况下,我们要排队,排队也有先后顺序,有些人早了点来,排完 ...

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

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

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

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

  6. javascript的快速排序法

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

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

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

  8. C#实现快速排序法

    现在有数组{ 3, 6, 2, 1, 9, 5, 4, 7 }; 然后用快速排序法把他们排序 1.首先 ,取出3作为比较数据 2.从最右边往左边比较找到第一个比3小的数据,把3在数组中的位置赋值为那个 ...

  9. 快速排序法QuickSort

    /** * * @author Administrator * 功能:交换式排序之快速排序 */ package com.test1; import java.util.Calendar; publi ...

随机推荐

  1. Struts2报错org.apache.jasper.JasperException: Invalid directive原因

    struts标签书写错误.<s:textfield name="us.username"/>对的<s:textfield name="us.userna ...

  2. js实现刷新

    Javascript刷新页面的几种方法: 代码如下:1,history.go(0) 2,location.reload() 3,location=location 4,location.assign( ...

  3. .NET 绝对路径的配置

    有时候因为用IIS配置网站,会导致一些全局引用有路径问题无法引用到.今天就说一下,关于全局引用的绝对路径的配置,譬如,由于IIS配置的虚拟路径,一些CSS,JS的引用找不到,又或者自定义的一些跳转出现 ...

  4. C:函数:功能:实现字符数组中所有字母的倒序存放并输出

    前两天小测碰到一道题,建立一个函数,功能:实现字符数组中所有字母的倒序存放并输出,一开始觉得简单跟数字数组差不多,运行一下发现很多格式错误,这些是不必要的错误,现在就来说下,先说一下代码思路:定义一个 ...

  5. KVM 初探

    KVM 是业界最为流行的 Hypervisor,全称是 Kernel-based Virtual Machine.它是作为 Linux kernel 中的一个内核模块而存在,模块名为 kvm.ko,也 ...

  6. 点分治X2

    1.聪聪可可 点分治板子 然而想那个 t1[1]*t1[2]*2+t1[0]*t1[0]想了好久 就是最基本的组合方法 毕竟(2,5)和(5,2)可是要算两次的 画画图就好了 (不要像我一样盯着大佬们 ...

  7. 在html中使用js

    1.使用defer属性可以让脚本在文档完全呈现出来之后在执行,延迟脚本总是按照制定他们的顺序进行. 2.使用async属性可以表示当前脚本不必等待其他脚本,也不必阻塞文档呈现,不能保证异步顺序按照它们 ...

  8. find + xargs + cp 遇到文件名中带空格如何处理

    一,需求为查询文件名为ZRSH开头的时间为7月至今的所有文件并打包 1.首先想到的就是find + xargs + cp  格式.. find 2016073* -type f  -name *ZRS ...

  9. Linux(以CentOS6.5示例)下安装Oracle官方最新版JDK(JDK1.8)

    本文地址http://comexchan.cnblogs.com/ ,作者Comex Chan,尊重知识产权,转载请注明出处,谢谢! 我们很多组件都需要使用Oracle最新版的JDK,所以需要在我们的 ...

  10. python爬虫——建立IP池,将可用IP存放到redis

    直接上代码,每行代码后面都有注释 import urllib.request import urllib import re import time import random import sock ...