首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

———交换排序

1.交换排序 基本思想:所谓交换,就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置,交换排序的特点是:将键值较大的记录向序列的尾部移动,键值较小的记录向序列的前部移动。...稳定性:稳定 3.快速排序 快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法, 其基本思想为:任取待排序元素序列中的某元素作为基准值,按照该排序码将待排序集合分割成两子序列,左子序列中所有元素均小于基准值...将区间按照基准值划分为左右两半部分的常见方式有: 1. hoare版本 在快速排序算法中,需要在找到左边比关键值大的元素和右边比关键值小的元素之后才进行元素交换,以确保左边的元素都比关键值小,右边的元素都比关键值大...但是在代码中目前的交换步骤存在问题,因为在while循环结束之后直接进行了一次元素交换,而应该是在找到左右指针位置后再进行交换。...使用两个指针begin和end分别指向数组的起始和末尾,开始移动指针以找到需要交换的元素。

7310
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    交换排序之高速排序

    今天大鹏哥跟大家一起学习下交换排序中的高速排序。 高速排序是对冒泡排序的一种改进。它的基本思想是。...通过一趟排序将待排记录切割成独立的两部分,当中一部分记录的keyword均比还有一部分的keyword小。则可分别对这两部分记录继续进行排序,以达到真个序列有序。...Step2、首先从high所指位置向前搜索找到第一个keyword小于pivotkey的记录和pivotkey交换。          Step3、从low所指位置向后搜索。...找到第一个keyword大鱼pivotkey的记录和pivotkey交换。          Step4、反复以上步骤直到low=high为止。...                              ↑(high)                     ↑(pivotkey) 2、从high所指位置向前搜索,找到第一个小于pivotkey的记录(此处为27)和枢轴记录互相交换

    27110

    排序算法之交换排序(冒泡排序、快速排序

    交换排序 所谓交换,是指根据序列中两个关键字的比较结果来对换这两个记录在排序中的位置。...冒泡排序 概念 冒泡排序的基本思想是:从前往后(或从后往前)两两比较相邻元素的值,若为逆序(即A[I-1]>A[I]),则交换它们,直到序列比较完。...我们称它为第一趟冒泡,结果是将最小的元素交换到待排序列的第一个位置(或将最大的元素交换到待排序列的最后一个位置),关键字最小的元素如气泡一样逐渐向上“漂浮”。最终一个一个排好了位置。...概念 快速排序的基本思想是基于分治法的:在待排序表L【1.。。...n】中任取一个元素pivot作为枢轴(通常取首元素),通过一趟排序将待排序表划分为独立的两部分,使其中一个表L【1.。。k-1】中的元素都大于枢轴pivot,另一个表L【k+1.。。。

    61330

    交换排序—冒泡排序(Bubble Sort)

    即:每当两相邻的数比较后发现它们的排序排序要求相反时,就将它们互换。 冒泡排序的示例: ?...对冒泡排序常见的改进方法是加入一标志性变量exchange,用于标志某一趟排序过程中是否有数据交换,如果进行某一趟排序时并没有进行数据交换,则说明数据已经按要求排列好,可立即结束排序,避免不必要的比较过程...本文再提供以下两种改进算法: 1.设置一标志性变量pos,用于记录每趟排序中最后一次进行交换的位置。由于pos位置之后的记录均已交换到位,故在进行下一趟排序时只要扫描到pos位置即可。...Bubble_1 ( int r[], int n) { int i= n -1; //初始时,最后位置保持不变 while ( i> 0) { int pos= 0; //每趟开始时,无记录交换...for (int j= 0; j< i; j++) if (r[j]> r[j+1]) { pos= j; //记录交换的位置 int tmp = r[j]; r[j]=r

    89720

    (2)交换排序之冒泡排序

    title: (2)交换排序之冒泡排序 date: 2019-02-10 13:00:00 +0800 update: 2019-02-10 13:00:00 +0800 author: me...tags: 算法 ---- 文章目录 (2)交换排序之冒泡排序 算法步骤 演示图 时间复杂度 空间复杂度 稳定性 Java代码实现 (1) 没有任何优化 (2) 对本身有排序的进行优化 (3) 部分有序...(2)交换排序之冒泡排序 算法步骤 比较相邻的元素。如果第一个比第二个大,就交换他们两个。 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。...如果对于一个本身有序的序列,或则序列后面一大部分都是有序的序列,上面的算法就会浪费很多的时间开销,这里设置一个标志flag,如果这一趟发生了交换,则为true,否则为false。...明显如果有一趟没有发生交换,说明排序已经完成。

    50460

    7.3.1 交换排序之冒泡排序

    所谓交换,就是根据序列中两个元素关键字的比较结果来对换这两个记录在序列中的位置。 冒泡排序算法的基本思想是:假设待排序表长为n,从后往前(或从前往后)两两比较相邻元素的值。...若为逆序(即A[i-1]>A[i]),则交换它们,直到序列比较完。我们称它为一趟冒泡。...结果将最小的元素交换到待排序的第一个位置(关键字最小的元素如气泡一般逐渐往上漂浮,直到水面,这就是冒泡排序名字的由来)。...,需要进行n-1趟排序,第i趟排序要进行n-i次关键字的比较,而且每次比较都必须移动元素3次来交换元素位置。...稳定性:由于当i<j且A[i].key=A[j].key时,不会交换两个元素,从而冒泡排序是一个稳定的排序方法。

    44520

    交换排序—快速排序(Quick Sort)

    3)此时基准元素在其排好序后的正确位置 4)然后分别对这两部分记录用同样的方法继续进行排序,直到整个序列有序。 快速排序的示例: (a)一趟排序的过程: ? (b)排序的全过程 ?...将比基准元素小的交换到低端 swap(&a[low], &a[high]); while(low < high && a[low] <= privotKey ) ++low; swap(&...但若初始序列按关键码有序或基本有序时,快排序反而蜕化为冒泡排序。为改进之,通常以“三者取中法”来选取基准记录,即将排序区间的两个端点与中点三个记录关键码居中的调整为支点记录。...快速排序是一个不稳定的排序方法。 快速排序的改进 在本改进算法中,只对长度大于k的子序列递归调用快速排序,让原序列基本有序,然后再对整个基本有序序列用插入排序算法排序。...将比基准元素小的交换到低端 swap(&a[low], &a[high]); while(low < high && a[low] <= privotKey ) ++low; swap(&

    36430

    交换与选择类排序

    各种排序算法所需辅助空间 1、 所有的简单排序方法(包括:直接插入、起泡和简单选择)和堆排序的空间复杂度为O(1); 2、 快速排序为O(logn ),为栈所需的辅助空间; 3、 归并排序所需辅助空间最多...5、直接插入排序:比较次数 最少n-1次;最多(n-1)(n+2)/2 移动次数 最少0; 最多(n-1)(n+4)/2 使用一个辅助存储空间,是稳定的排序; 6、折半插入排序:比较次数 最少与最多同...,都是n*log2n(其中2为底,下边表示同), 移动次数 最少0,最多时间复杂度为O(n2);(n的平方,以下也如此表示); 使用一个辅助存储空间,是稳定的排序; 7、冒泡排序: 比较最少为:n-...log2n,最多为n的平方;是不稳定的排序; 10、 堆排序: 比较和移动次数没有好坏之分,都是O(n*log2n); 使用一个辅存空间,是不稳定的排序; 11、2-路归并排序:比较和移动次数没有好坏之分...,都是O(n*log2n); 需要n个辅助存储空间,是稳定的排序

    37210

    排序2】交换排序:让代码更优雅

    交换排序 1、基本思想及特点 基本思想:所谓交换,就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置。 特点:将键值较大的记录向序列的尾部移动,键值较小的记录向序列的前部移动。...2、冒泡排序 冒泡排序(Bubble Sort)是排序算法里面比较简单的一个排序。...它重复地走访要排序的数列,一次比较两个数据元素,如果顺序不对则进行交换,并一直重复这样的走访操作,直到没有要交换的数据元素为止。...swap(array,j,j+1); flg = true; } } //没有交换证明有序了...冒泡排序是一种非常容易理解的排序 时间复杂度:O(N^2) 空间复杂度:O(1) 稳定性:稳定 3、快速排序(挖坑法) 快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法,其基本思想为

    14910

    【数据结构】排序交换排序(冒泡 | 快排)

    前言 在之前的博客中介绍了插入排序,有需要的可以点这个链接: link,这次来介绍交换排序,包括冒泡和快排。 话不多说,正文开始。 2....交换排序 基本思想:所谓交换,就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置。 交换排序的特点是:将键值较大的记录向序列的尾部移动,键值较小的记录向序列的前部移动。...交换排序这里介绍冒泡排序和快速排序,来一起看看。 3. 冒泡排序 动图形象的展示了冒泡排序的过程。...冒泡排序的特性总结: 冒泡排序是一种非常容易理解的排序 时间复杂度:O(N^2) 空间复杂度:O(1) 稳定性:稳定 3.1 分析 交换排序肯定离不开交换,就先写一个Swap。...快速排序 快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法。

    13510

    ————排序总结——插入排序(直接排序和希尔排序)—选择排序(选择排序和堆排序)-交换排序(冒泡排序和快速排序)—归并排序(归并排序

    3.交换排序 具体分析过程见我的博客插入排序: [数据结构]———交换排序-CSDN博客 1.冒泡排序 // 时间复杂度:O(N^2) // 最好情况是多少:O(N) void BubbleSort(int...下面是对冒泡排序的分析总结: 基本思想:冒泡排序的基本思想是通过相邻元素的比较和交换来实现排序。每一轮比较都会将当前未排序部分的最大(或最小)元素“冒泡”到末尾。...最差情况是待排序数组逆序,需要进行n-1轮比较,并且每轮比较都需要交换元素。...堆排序: 算法思想:堆排序利用堆这种数据结构进行排序。首先将待排序序列构建成一个大顶堆(或小顶堆),然后依次将堆顶元素与末尾元素交换,并重新调整堆,直到整个序列有序。...交换排序是一种通过元素之间的交换来进行排序的算法,包括冒泡排序和快速排序

    11810
    领券