小和问题

现有数组[1,3,4,2,5]

1左边是0(小于1),所以1的小和为0

3左边是1(小于3),所以3的小和为1

4左边是1、3(均小于4),所以4的小和为1+3=4

2左边是1、3、4(只有1小于2),所以2的小和为1

5左边是1、3、4、2(均小于5),所以5的小和为1+3+4+2=10

数组的小和为0+1+4+1+10=16

上述方法是从“左边有几个数比当前数小”的角度去解决

还可以转化为“右边有几个数比当前数大”来解

现有数组[1,3,4,2,5]

1右边有4个数大于1,有4个小和(4);

3右边有2个数大于3,有2个小和(6);

4右边有1个数大于4,有1个小和(4);

2右边有1个数大于2,有1个小和(2);

5右边没有(0)

4+6+4+2+0=16

荷兰国旗问题

问题一

给定一个数组arr,和一个数num,请把小于等于num的数放在数组的左边,大于num的数放在数组的右边。要求额外空间复杂度0(1),时间复杂度O(N)

思路:

准备一个变量表示小于等于num的右边界【num定为5算了】

≤)[3,5,6,7,4,3,5,8]

i

此时有两种逻辑:

1、 当前数[i]≤num,则把当前的数[i]和小于等于区域"≤)"中的下一个数交换,然后"≤)"向右扩,i++;

2、当前数[i]>num,直接跳下一个数,i++;

≤)[3,5,6,7,4,3,5,8]

i

当指针来到3时,3≤5,区域"≤)"向右扩,i++

≤[3),5,6,7,4,3,5,8]

i
≤[3,5),6,7,4,3,5,8]

i

到5时同理

到6时满足第二种条件,直接跳下一个数,i++

≤[3,5),6,7,4,3,5,8]

i
≤[3,5),6,7,4,3,5,8]

i

到7时同理,直接跳下一个数,i++

到4时满足条件1,把4与"≤)"区域的下一个数交换,4与6交换,区域"≤)"向右扩,i++

≤[3,5),4,7,6,3,5,8]

i
≤[3,5,4),7,6,3,5,8]

i
≤[3,5,4),7,6,3,5,8]

i

以此类推,当区域"≤)"扩到整个数组范围时结束

问题二(荷兰国旗问题)

给定一个数组arr,和一个数num,请把小于num的数放在数组的左边,等于num的数放在数组的中间,大于num的数放在数组的右边。要求额外空间复杂度0(1),时间复杂度0(N)

思路:

还是跟前一个问题类似,准备两个变量,一个表示小于5的右边界,另一个表示大于5的左边界

<)[3,5,6,3,4,5,2,6,9,0](>

i

此时每来到一个置就会有3种情况

1、当前数[i]<num,则把当前的数[i]和小于区域"<)"中的下一个数交换,然后"<)"向右扩,i++;

2、当前数[i]=num,,直接跳下一个数,i++;

3、当前数[i]>num,则把当前的数[i]和大于区域">)"中的前一个数交换,然后">)"向左扩,i++;

当指针来到3时,3<5,区域"<)"向右扩,i++

<[3),5,6,3,4,5,2,6,9,0](>

i
<[3),5,6,3,4,5,2,6,9,0](>

i

当指针来到5时,等于5,直接跳下一个

<[3),5,6,3,4,5,2,6,9,0](>

i
<[3),5,0,3,4,5,2,6,9,6](>

i
<[3),5,0,3,4,5,2,6,9,(6]>

i

当指针来到6时,6>5,6和大于区域">)"中的前一个数交换,6和0交换,i原地不动(因为还没检查过它)

此时,检查新交换到i位置的数,发现其<5,则0和小于区域"<)"中的下一个数交换,然后"<)"向右扩,i++;

<[3),5,0,3,4,5,2,6,9,(6]>

i
<[3),0,5,3,4,5,2,6,9,(6]>

i
<[3,0),5,3,4,5,2,6,9,(6]>

i

以此类推,当i遇到大于区域的边界时停止

最后两边就剩下大于小于的区域,而中间是等于的

结束

快排

1.0版

例如

现在有一个数组,拿数组的最后一个数作为划分值

然后让它前面的一段做到左边的为≤num,右边的为>num,设num为5吧

然后5和大于区域的第一个数做交换

然后再把圈上的区域再重复进行之前的操作(拿最后一个数作为划分值)

例如:

因为每次只保证一个数排好,所以递归到最后一定是有序的

2.0版

是以荷兰国旗问题为基础,也是最开始选数组的最后一个数作为划分值,不同的是,每次排完数组中间都是等于划分值的数,相当于每次搞定一批数的排序。

然后再在小于和大于区域重复上述操作直到排序结束

以5为例子

2.0和1.0在一些人为构建的数据中有可能会存在复杂度降低(好情况)或变高(坏情况)的情况

3.0版

在数组中随机选一个数作为划分值,将该数与数组最后一个数做交换再划分

由此,划分时出现好情况和坏情况就变成了概率事件,而且是等概率事件,因此该算法通过数学计算后的显示复杂度为O(Nlog2N)

【算法day3】小和、荷兰国旗、快排的更多相关文章

  1. 排序算法C语言实现——冒泡、快排、堆排对比

    对冒泡.快排.堆排这3个算法做了验证,结果分析如下: 一.结果分析 时间消耗:快排 < 堆排 < 冒泡. 空间消耗:冒泡O(1) = 堆排O(1) < 快排O(logn)~O(n) ...

  2. C++学习(三十八)(C语言部分)之 排序(冒泡 选择 插入 快排)

    算法是解决一类问题的方法排序算法 根据元素大小关系排序 从小到大 从大到小冒泡 选择 插入 快排希尔排序 归并排序 堆排序 冒泡排序 从头到尾比较 每一轮将最大的数沉底 或者最小数字上浮 选择排序 1 ...

  3. 在链表上实现 Partition 以及荷兰国旗问题

    在链表上实现 Partition 以及荷兰国旗问题 作者:Grey 原文地址: 博客园:在链表上实现 Partition 以及荷兰国旗问题 CSDN:在链表上实现 Partition 以及荷兰国旗问题 ...

  4. 荷兰国旗问题、快排以及BFPRT算法

    荷兰国旗问题 给定一个数组arr,和一个数num,请把小于num的数放数组的左边,等于num的数放在数组的中间,大于num的数放在数组的右边.要求额外空间复杂度O(1),时间复杂度O(N). 这个问题 ...

  5. F#之旅4 - 小实践之快排

    参考文章:https://swlaschin.gitbooks.io/fsharpforfunandprofit/content/posts/fvsc-quicksort.html F#之旅4 - 小 ...

  6. Java常见的几种排序算法-插入、选择、冒泡、快排、堆排等

    本文就是介绍一些常见的排序算法.排序是一个非常常见的应用场景,很多时候,我们需要根据自己需要排序的数据类型,来自定义排序算法,但是,在这里,我们只介绍这些基础排序算法,包括:插入排序.选择排序.冒泡排 ...

  7. 冒泡,快排算法之javascript初体验

    引子:javascript实际使用的排序算法在标准中没有定义,可能是冒泡或快排.不用数组原生的 sort() 方法来实现冒泡和快排. Part 1:冒泡排序(Bubble Sort) 原理:临近的两数 ...

  8. scala写算法-快排

    快排算法很经典,今天用scala的函数式思维来整理一下并实现: def qsort(list: List[Int]):List[Int]=list match { case Nil=>Nil c ...

  9. javascript高级排序算法之快速排序(快排)

    javascript高级排序算法之快速排序(快排)我们之前讨论了javascript基本排序算法 冒泡排序 选择排序 插入排序 简单复习: 冒泡排序: 比较相邻的两个元素,如果前一个比后一个大,则交换 ...

  10. 《算法导论》——重复元素的随机化快排Optimization For RandomizedQuickSort

    昨天讨论的随机化快排对有重复元素的数组会陷入无限循环.今天带来对其的优化,使其支持重复元素. 只需修改partition函数即可: int partition(int *numArray,int he ...

随机推荐

  1. [转帖]官网:Nacos的授权验证

    https://nacos.io/zh-cn/docs/v2/guide/user/auth.html 注意 Nacos是一个内部微服务组件,需要在可信的内部网络中运行,不可暴露在公网环境,防止带来安 ...

  2. [转帖]CPU计算性能speccpu2006的测试方法及工具下载

    https://www.yii666.com/blog/335517.html CPU计算性能speccpu2006的测试方法及工具下载 简介 测试原理 目录结构 测试方法 基准测试项解析 测试结果 ...

  3. Docker镜像的基本操作总结

    摘要 容器化是上个十年比较火的技术. 现在看起来在进行总计有点晚了. 不过linux是三十年前的,我依旧没有总结好 道理是一样的. 技术不在于新旧, 重要的是学习到原理. Docker的重要概念 Re ...

  4. Opentelemetry Metrics SDK

    Metrics SDK 目录 Metrics SDK 目标 期望 SDK 术语 数据流图表 要求 SDK MeterProvider Shutdown SDK:Instrument注册 SDK: Re ...

  5. NOI2023 游记

    不完全按时间顺序写.记录 NOI 的一些琐事. 从 XDFZ 坐大巴 5 个小时来到成七.第一眼看到的是一个放着 NOI 牌子的台阶,还有一个签名墙.好像在我们之前到的人不太多? 用中英双语签名(冷月 ...

  6. vue中$once的使用

    $once 可以给组件实例绑定一个自定义事件,但该事件只能被触发一次,触发之后随即被移除 $once的简单使用 <template> <div> <button @cli ...

  7. 小记录 单选框的注意点 html中字符串拼接 el-upload手动上传 表格跳转 v-for动态添加背景色 控制label标签于文本框之间的间距

    在element-ui中 单选框的v-model的值最好是一个字符串 否者可能不能够进行数据回填哈 单选框 的类型必须是字符串类型哈 在elemnet-ui中 如果你想从A页面拿到B页面中的值 可以有 ...

  8. VUe2.0 和 Vue3.0 的生命周期作对比

    VUe2.0 和 Vue3.0 的生命周期作对比 beforeCreate -> 请使用 setup() created -> 请使用 setup() beforeMount -> ...

  9. elementUI日期选择器,对日期格式进行处理

    使用elementUI日期选择器中,获取不同格式的时间 <el-form-item label="归零时间:" prop="zeroing"> &l ...

  10. 【验证码逆向专栏】数美验证码全家桶逆向分析以及 AST 获取动态参数

    声明 本文章中所有内容仅供学习交流使用,不用于其他任何目的,不提供完整代码,抓包内容.敏感网址.数据接口等均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关! 本文章未经许 ...