当前位置:首页 > 资讯 > 正文

分解代码快速理解 快速排序与归并排序

分解代码快速理解 快速排序与归并排序

目录

概念(来自于百度搜索):

(1)首先设定一个分界值,通过该分界值将数组分成左右两部分。
(2)将大于或等于分界值的数据集中到数组右边,小于分界值的数据集中到数组的左边。此时,左边部分中各元素都小于分界值,而右边部分中各元素都大于或等于分界值。
(3)然后,左边和右边的数据可以独立排序。对于左侧的数组数据,又可以取一个分界值,将该部分数据分成左右两部分,同样在左边放置较小值,右边放置较大值。右侧的数组数据也可以做类似处理。
(4)重复上述过程,可以看出,这是一个递归定义。通过递归将左侧部分排好序后,再递归排好右侧部分的顺序。当左、右两个部分各数据排序完成后,整个数组的排序也就完成了。

从以上的四点介绍中可以得出三点有效信息:
第一点和第二点为划分区间
第三点为交换
第四点为递归

从以上核心介绍中,可以写出以下快速排序的函数:
以下整合的C++代码:

 
 

学习完快速排序后,归并排序的核心思想:
(1)确定分界点
(2)递归排序
(3)归并(合二为一)(难点/重点)
其中是把快速排序中的(2)与(3)进行代码上的交换。

算法模板:

 

练习题:逆序对的数量

给定一个长度为 n
的整数数列,请你计算数列中的逆序对的数量。
逆序对的定义如下:对于数列的第 i
个和第 j
个元素,如果满足 i<j
且 a[i]>a[j]
,则其为一个逆序对;否则不是。
输入格式
第一行包含整数 n
,表示数列的长度。
第二行包含 n
个整数,表示整个数列。
输出格式
输出一个整数,表示逆序对的个数。
数据范围
1≤n≤100000,
数列中的元素的取值范围 [1,109]。
输入样例:
6
2 3 4 5 6 1
输出样例:
5

如果是用暴力的做法为O(n2) 用归并排序解决比暴力解决时间复杂度要低。

思路:利用归并排序的算法思想,讲归并排序分成两个部分,在输入数组中,可以分为三个部分。一个部分左边,一个部分为右边,还要一个部分为左右两边都有。
核心:这道题是利用归并排序的思路进行解决的,从归并的算法中可以看出利用递归可以把问题分解成为一个个子问题,利用子问题的特性进行把所有问题进行一个会合。
对于mid中我们只需要找到左边第一个大于B的数字A,那么A后面的数字都大于B。根据下标进行计算,则需要统计的数目为:mid-i+1

最新文章