收到网站建设账务处理旅游类网站做百度竞价

news/2025/9/22 20:55:47/文章来源:
收到网站建设账务处理,旅游类网站做百度竞价,建筑模板网,动易网站管理快速排序 快速排序递归实现前言一、Hoare版本#xff08;一#xff09;算法运行图例#xff08;二#xff09;算法核心思路#xff08;三#xff09;算法实现步骤#xff08;1#xff09;单趟#xff08;2#xff09;多趟 #xff08;四#xff09;码源详解 递归实… 快速排序 快速排序递归实现前言一、Hoare版本一算法运行图例二算法核心思路三算法实现步骤1单趟2多趟 四码源详解 递归实现1Hoare版本先行版2Hoare版本发行版 五Hoare算法 实现背后的理论支持六效率优化Hoare排序的效率分析1时间复杂度 ON*logN稳定性 不稳定 七代码优化1三数取中1优化思路 2三数取中优化 后的代码3效果对比 2小区间优化—— 小区间不再进行递归分割排序降低递归次数1优化思路 2整体优化后的完整代码二、挖坑法版本前言一算法运行图例二算法核心思路三算法实现步骤1单趟2多趟 四码源详解三、前后指针版本一算法运行图例二算法核心思路三算法实现步骤1单趟2多趟 四码源详解 快速排序递归实现 前言 快速排序是Hoare于1962年提出的一种 二叉树结构的交换排序方法。 一、Hoare版本 一算法运行图例 二算法核心思路 任取待排序元素序列中的某元素作为基准值按照该排序码将待排序集合 分割成两子序列 左子序列中所有元素均小于基准值右子序列中所有元素均大于基准值然后最左右子序列重复该过程直到所有元素都排列在相应位置上为止。 三算法实现步骤 1单趟 找一key 【注意我们实际上控制的是key的下标keyi而不是用新开辟的变量去储存它的值用新开辟的变量去储存最后交换的也只是与该变量进行交换而不是在数组中与原数组的值进行交换】 【图讲解】begin从左开始遍历左边找比key大的。end从右开始遍历右边找比key小的。等于key的值不动。两边都找到了互换最后相遇的地方就是key排好序后要放的位置正确的位置与key互换 【有理论支持的请看下文】 此时 【左边的都比key小】中间key【右边的都比key大】 要是左右要是都有序 》整体实现有序 多趟解决 2多趟 对排好的key的左边再进行单趟排序对排好的key的右边再进行单趟排序左边右边分别再排好两边key的位置再分左右再进行单趟 类似 二叉树前序递归的思想根、左子树、右子树。 四码源详解 递归实现 1Hoare版本先行版 按照思路写出来 了大家看看都存在些什么问题。 //递归实现 // Hoare版本先行版 int PartSort1(DataType* a,int left,int right) {int key a[left]; while (left right) { //相遇是跳出循环的条件 //right 先走if (a[key] a[right]) { right--; } //找到a[right]a[keyi]的情况就停下if (a[left] a[key]) { //left 同理left;}Swap(a[left], a[right]); //都找到后互换}Swap(a[left], a[key]);//相遇后跳出循环 交换a[keyi]和left,right相遇的位置 }坑1a[key] a[right]若a[key] 一直比 a[right]要小则right则回一直向左right–遍历则会出现越界的问题同理left那边也是 解决方法leftright,控制right不要越界避免该序列本来就是有序一直比a[keyi]要大而一直right–越出边界的情况的情况 坑2a[keyi] a[right]若不跳则要是两边都遇到相等的值则两边无法再进入if语句进行right–或left而进入死循环 解决方法a[keyi]a[right]时都跳 坑3int key a[left]; Swap(a[left], a[key]); 真正在换的是哪个 key是局部变量相当于在栈区开辟了一块空间用于存储a[left]的值。实际与数组a[left]进行交换的是局部变量这块空间里面的值对数组原始的最左边并不产生任何影响 解决方法int left keyi; 记录的应该是下标通过控制下标来达到改变原数组 2Hoare版本发行版 // Hoare版本发行版 int PartSort1(DataType* a, int left, int right) {int keyi left; //保存left的下标while (left right) { //相遇是跳出循环的条件 //right 先走if (left right a[keyi] a[right]) { //leftright,控制right不要越界避免该序列本来就是有序一直比a[keyi]要大而一直right--越出边界的情况的情况right--;} //找到a[right]a[keyi]的情况就停下if (left right a[left] a[keyi]) { //left 同理left;}Swap(a[left], a[right]); //都找到后互换}Swap(a[left], a[keyi]);//相遇后跳出循环 交换a[keyi]和left,right相遇的位置 } 五Hoare算法 实现背后的理论支持 ★☆ 最后相遇的地方 就是key排好序后要放的位置正确的位置是怎么做到的呢 右边先走做到的。 有了上面的理论保证停下来的值一定比key小才敢进行交换。 六效率优化 Hoare排序的效率分析 1时间复杂度 ON*logN 如果每次选到的 keya[ left ] 都是中位数这将会非常高效 【因为每单趟排好一次key就能落入到其正确的位置】 理想状态下是满二叉树的分割【二分 ON*logN】 而最差的情况有序接近有序【每次取到的key都选到整个数组中次大或次小的数每个keyleft或right都要遍历一遍数组 ON^2】 但随机取的值肯定不是像这样有序或接近有序的这种都是已经给你排好了的 所以总体来说Hoare在时间复杂度上是更接近于 ON*logN 的 。 稳定性 不稳定 七代码优化 1三数取中 那么我们针对序列可能会出现最差情况有序的情况做一个程序优化——三数取中 。 1优化思路 int midleftright/ 2 对比 a[mid]、a[left]、a[right] 三个值取值大小为中间的那个数 。【大大降低了取两边极端的可能让取到的数更偏向于有序序列中间的数】 //三数取中 取的不是位置在中间的值而是值大小位于中间的值 int Getmidi(DataType* a,int left,int right) {int mid (left right) / 2;//left mid rightif (a[left] a[mid]) {if (a[mid] a[right]) //mid为中间值return mid;else if (a[left] a[right]) { //mid为最大值return left; //left为中间值}else {return right;}}else { //a[left]a[mid]if (a[mid] a[right]) { //mid为中间值return mid;}else if (a[left]a[right]) { //left为中间值mid最小return left;}else {return right;}}}2三数取中优化 后的代码 //三数取中 取的不是位置在中间的值而是值大小位于中间的值 int Getmidi(DataType* a,int left,int right) {int mid (left right) / 2;//left mid rightif (a[left] a[mid]) {if (a[mid] a[right]) //mid为中间值return mid;else if (a[left] a[right]) { //mid为最大值return left; //left为中间值}else {return right;}}else { //a[left]a[mid]if (a[mid] a[right]) { //mid为中间值return mid;}else if (a[left]a[right]) { //left为中间值mid最小return left;}else {return right;}}}// Hoare版本发行版 int PartSort1(DataType* a, int left, int right) {//三数取中int midi Getmidi(a, left, right);Swap(a[left], a[midi]); //交换a[left]与a[midi]值的位置 int keyi left; //保存left的下标while (left right) { //相遇是跳出循环的条件 //right 先走if (left right a[keyi] a[right]) { //leftright,控制right不要越界避免该序列本来就是有序一直比a[keyi]要大而一直right--越出边界的情况的情况right--;} //找到a[right]a[keyi]的情况就停下if (left right a[left] a[keyi]) { //left 同理left;}//坑1a[keyi] a[right]若不跳则要是两边都遇到相等的值则两边无法再进入if语句进行right--或left而进入死循环//更正a[keyi]a[right]时都跳Swap(a[left], a[right]); //都找到后互换}Swap(a[left], a[keyi]);//相遇后跳出循环 交换a[keyi]和left,right相遇的位置 } 3效果对比 对 有序/接近有序 的序列中优化效果明显。 对 随机 就正常。 2小区间优化—— 小区间不再进行递归分割排序降低递归次数 1优化思路 满二叉树整体节点的个数2^h-1 等比数列求和 。 最后一层的节点数就已经占了整体的 50% 。 最后三层的节点数就已经约占整体的 80% 的节点个数了 。 那么最后这三层约占整体80%的节点数若采用递归的方式将是对栈帧的一个很大的开销。因为我们最后这三层区间被分的比较小了若采用更适用于小区间数排序的优化无疑是对效率很大的提升 那么小区间优化我们可以选择哪个小区间数排序方式呢 希尔排序数据大时比较有序目的让大的数更快的到后面去 插入排序少的数最坏情况逆序比所有数都小 因为小区间数比较少对比起来比较快所以这里选择 插入排序 更快速便捷高效。 //小区间优化版本—— 小区间不再进行递归分割排序降低递归次数 void QuickSort1(DataType* a, int begin, int end) {if (begin end)return;//10个数就已经占3层递归了而递归层数中尾三层所占节点的总数 约占80%这尾三层再继续用递归的方法而改用小区间数据排序优化的思路能让程序整体得到进一步的优化if ((end - begin 1) 10) {int keyi PartSort3(a, begin, end);QuickSort1(a, begin, keyi - 1);QuickSort1(a, keyi1, end);}else { //改用小区间数据优化排序InsertSort(a begin, end - begin 1); // abegin 找到对应数组所在的位置} }2整体优化后的完整代码 //三数取中 取的不是位置在中间的值而是值大小位于中间的值 int Getmidi(DataType* a,int left,int right) {int mid (left right) / 2;//left mid rightif (a[left] a[mid]) {if (a[mid] a[right]) //mid为中间值return mid;else if (a[left] a[right]) { //mid为最大值return left; //left为中间值}else {return right;}}else { //a[left]a[mid]if (a[mid] a[right]) { //mid为中间值return mid;}else if (a[left]a[right]) { //left为中间值mid最小return left;}else {return right;}}}// Hoare版本发行版 int PartSort1(DataType* a, int left, int right) {//三数取中int midi Getmidi(a, left, right);Swap(a[left], a[midi]); //交换a[left]与a[midi]值的位置 int keyi left; //保存left的下标while (left right) { //相遇是跳出循环的条件 //right 先走if (left right a[keyi] a[right]) { //leftright,控制right不要越界避免该序列本来就是有序一直比a[keyi]要大而一直right--越出边界的情况的情况right--;} //找到a[right]a[keyi]的情况就停下if (left right a[left] a[keyi]) { //left 同理left;}//坑1a[keyi] a[right]若不跳则要是两边都遇到相等的值则两边无法再进入if语句进行right--或left而进入死循环//更正a[keyi]a[right]时都跳Swap(a[left], a[right]); //都找到后互换}Swap(a[left], a[keyi]);//相遇后跳出循环 交换a[keyi]和left,right相遇的位置 }//小区间优化版本—— 小区间不再进行递归分割排序降低递归次数 void QuickSort1(DataType* a, int begin, int end) {if (begin end)return;//10个数就已经占3层递归了而递归层数中尾三层所占节点的总数 约占80%这尾三层再继续用递归的方法而改用小区间数据排序优化的思路能让程序整体得到进一步的优化if ((end - begin 1) 10) {int keyi PartSort3(a, begin, end);QuickSort1(a, begin, keyi - 1);QuickSort1(a, keyi1, end);}else { //改用小区间数据优化排序InsertSort(a begin, end - begin 1); // abegin 找到对应数组所在的位置} }二、挖坑法版本 前言 挖坑法是Hoare排序的一个思路上的优化不用再考虑为什么右边先走。 因为一开始的坑就在左边那么一开始就得先从右边开始找找比坑小的数。 一算法运行图例 二算法核心思路 和Hoare的思路一样只不过这里是先挖好一个坑再开始排。如果在左边挖坑则从右边开始找如果在右边挖坑则从左边开始找。 三算法实现步骤 1单趟 int key a[left]; //保存好key值以后,左边形成第一个坑右边先走找小填到左边的坑右边形成新的坑左边再走找大填到右边的坑左边形成新的坑位left、right 相遇跳出循环。最终相遇一定在坑上相遇因为left、right其中一个必在坑位上且该坑位就是key值该在的有序序列中正确的位置 和Hoare版本的同理 。将key保留的最开始坑位的值赋给现在left、right相遇所在的坑位。 2多趟 对排好的key的左边再进行单趟排序对排好的key的右边再进行单趟排序左边右边分别再排好两边key的位置再分左右再进行单趟 四码源详解 // 快速排序——挖坑法 int PartSort2(int* a, int left, int right) {//三数取中——取位值位于中间的值int midi Getmidi(a, left, right);Swap(a[left], a[midi]);int key a[left]; //保存好key值以后,左边形成第一个坑int hole left; //单趟完成的返回的条件while (left right) {//右边先走找小填到左边的坑右边形成新的坑while (left right key a[right]) {right--;}a[hole] a[right];hole right;//左边再走找大填到右边的坑左边形成新的坑位while (left right a[left] key) {left;}a[hole] a[left];hole left;}//最后把储存的key的值填入坑位不用怕坑位的数被覆盖因为原坑位的数在这之前就已经赋到其他地方了a[hole] key;return hole; //返回已经排好正确位置的坑位位置}三、前后指针版本 一算法运行图例 二算法核心思路 cur一直向前遍历不管是遇到大的还是遇到小的。 而prev遇小的向前把小的交换过来遇到大的就停下等遇到小的时候就将其交换覆盖。旨在把小的放其左边大的放其右边。 cur越界后遍历结束。此时 prev 所在的地方正是key值该在的有序序列中正确的地方。 三算法实现步骤 1单趟 三数取中 _ 取中间值 赋给keyint prev left ; int cur prev 1; cur遇比key小的交换Swap(a[prev],a[cur]);把小的放其左边cur越界遍历结束Swap ( a[prev],a[keyi] ); 此时 prev 所在的地方正是key值该在的有序序列中正确的地方。 2多趟 对排好的key的左边再进行单趟排序对排好的key的右边再进行单趟排序左边右边分别再排好两边key的位置再分左右再进行单趟 四码源详解 先行版 这样写存在什么问题 // 快速排序前后指针法 —— 先行版 int PartSort3(int* a, int left, int right) {int midi Getmidi(a, left, right);Swap(a[left], a[midi]);int prev left;int cur prev 1;int keyi left;while (cur right) { //cur越界结束while (cur right a[cur] a[keyi]) { //没有碰到比key小的就一直向后遍历cur;}//找到了prev; //遇小的了就prevSwap(a[prev], a[cur]);交换Swap(a[prev], a[cur]);}//cur越界后代表遍历结束//在a[prev] 的位置将key值赋予它key该在的正确位置Swap(a[prev], a[keyi]);return prev; }当cur一直没有再遇到小的cur将会越界而这仅会跳出内层cur向后遍历的循环但程序仍在外层交换的循环中走。 所以cur越界后程序仍要向下运行代码这时交换的不再是数组中的数值而是数组外后一位cur越界后位置的数值。 所以应不再进行交换。交换已经结束了。应跳出外层交换 a[prev] 和 a[cur] 的循环。进行下一步 a[prev] 与 a[keyi] 的交换交换到key在有序中的正确位置。 发行版一 当判断出cur越界即可break跳出循环不再进行 a[prev] 与 a[cur] 的交换 // 快速排序前后指针法 —— 先行版 int PartSort3(int* a, int left, int right) {int midi Getmidi(a, left, right);Swap(a[left], a[midi]);int prev left;int cur prev 1;int keyi left;while (cur right) { //cur越界结束while (cur right a[cur] a[keyi]) { //没有碰到比key小的就一直向后遍历cur;}if (cur right) { //当判断出cur越界即可break跳出循环不再进行 a[prev] 与 a[cur] 的交换break;}//找到了prev; //遇小的了就prevSwap(a[prev], a[cur]);交换Swap(a[prev], a[cur]);}//cur越界后代表遍历结束//在a[prev] 的位置将key值赋予它key该在的正确位置Swap(a[prev], a[keyi]);return prev; }发行版二 // 快速排序前后指针法 int PartSort3(int* a, int left, int right) {int midi Getmidi(a, left, right);Swap(a[left], a[midi]);int prev left;int cur prev 1;int keyi left;while (cur right) { //cur越界结束//写法一if (a[cur] a[keyi]) { Swap(a[prev],a[cur]); //在还没遇到大的之前cur prev 1; a[prev] a[cur];数组自己与自己交换//遇小交换的意义将比其小的值放左边比其大的值放右边}//写法二if (a[cur] a[keyi] prev ! cur); { //如果不想要自己与自己交换的这种不必要的交换prev ! cur条件也可以这么写Swap(a[prev], a[cur]);}cur;}//cur越界后代表遍历结束//在a[prev] 的位置将key值赋予它key该在的正确位置Swap(a[prev],a[keyi]); return prev; }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/910345.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网站官网做手机网站优

文章目录 Python基于joblib的并行计算适用场景使用示例总结爬虫&joblib使用`joblib`的场景注意事项使用实例结论joblib介绍简单示例多参数并行并行时CPU是怎么分配的何时选用并行进程&线程进程和线程之间的关系

大气手机网站模板网站设计规划信息技术教案

文章目录 0. 前言1. 基本用法1.1 转换为Tensor1.2 图像大小调整1.3 随机裁剪1.4 中心裁剪1.5 随机翻转1.6 随机旋转1.7 填充1.8 组合变换 2. 进阶用法2.1 归一化2.2 色彩空间转换2.3 颜色抖动2.4 随机仿射2.5 透视变换2.6 自定义变换 0. 前言 按照国际惯例,首先声明…

中国住房和城乡建设部查询网站6wordpress极客主题

LabVIEW开发分段反射器测试台 随着对太空的观察需求越来越远,而不是当前技术(如哈勃望远镜)所能达到的,有必要增加太空望远镜主镜的尺寸。但是,增加主镜像的大小时存在几个问题。随着反射镜尺寸的增加,制造…

k8s系列--资源清单yml文件

集群资源分类 名称空间级别:kubeamd k8s,kube-system 集群级别: 元数据类型: 注意,yml文件不支持tab键的缩进,会报错docker pull 192.168.68.253:8253/library/nginx:latest 编写资源清单:注意,Pod首字母必须大…

网站建设的软件叫啥网站热度查询

背景 由于最近需要使用paddleocr,因此需要安装依赖paddlepaddle-gpu,不管怎么安装cuda11.6-11.8安装了一遍,都无法正常安装成功。如下所示: 环境:wsl2linux18.04 >>> import paddle >>> paddle.u…

k8s系列--容器生命周期

容器运行的流程:kubectl指令->api-server->etcd->kublet->CRI(容器运行接口)->容器生命周期 init C:ini-pod.yml apiVersion: v1 kind: Pod metadata: name: myapp-pod labels: app: myapp spec: co…

k8s系列(14)--探针检测

apiVersion: v1 kind: Pod metadata: name: readiness-httpget-pod namespace: default spec: containers:name: readiness-httpget-container image: 192.168.68.253:8253/library/nginx:latest imagePullPolicy: IfN…

k8s系列--控制器yml(15)

extensions/v1betal版本在1.9被废弃 apiVersion: apps/v1 kind: ReplicaSet metadata: name: frontend spec: replicas: 3 selector: matchLabels: tier: frontend template: metadata: labels: tier: frontend spec: …

做微商网站发帖免费教程龙岩建设局网站罗小波

前言对于大部分.NET 开发者来说, 都比较熟悉目前流行的ABP框架, 基于开源的ABP框架, 可以自己进行二次开发, 无需重新开发一些基础功能,例如: 用户角色管理、权限、组织、多租户等等。但是对于ABP框架来说, 提供给.NET开发者的可选项非常少, 目前也仅仅是提供了基于Web的解决方…

沈阳新民网站建设成都网络公司服务内容

买了个大华摄像头,除了抗噪方面效果不好,我是很满意的。前一段时间摄像头启动出了点问题(忘记拔掉SD卡),于是买了个海康的。 大华摄像头是3寸,海康是2寸。视频效果差多了。看来大有大的道理。更可恨的是&a…

普通网站服务器微信公众号开发是否需要建立网站

这片博文我们会详细说明MySQL本身的日志,不包含重做日志和undo日志(这两个日志是innodb存储引擎的日志)。 MySQL本身的日志有以下几种(MySQL5.7版本): 错误日志慢查询日志通用日志二进制日志错误日志 默认情…

上海网站建设报价单wordpress捐

正整数n若是它平方数的尾部&#xff0c;则称n为同构数。比如6是其平方数36的尾部&#xff0c;76是其平方 数5776的尾部&#xff0c;6与76都是同构数。输入正整数&#xff0c;判断是否为同构数。如果是&#xff0c;那么输出 n1;如果不是&#xff0c;那么输出n0。 #include <…

京东联盟新手没有网站怎么做推广网络信息有限公司

看过很多博主通过 Object Detection 实现了一些皮卡丘捕捉&#xff0c;二维码检测等诸多特定项的目标检测。而我跟着他们的案例来运行的时候&#xff0c;不是 Tensorflow 版本冲突&#xff0c;就是缺少什么包&#xff0c;还有是运行官方 object_detection_tutorial 不展示图片等…

博山专业网站优化哪家好正规的佛山网站建设价格

在这个快速变化的科技时代&#xff0c;作为独立开发者&#xff0c;你是否常常被繁琐的开发任务压得喘不过气&#xff1f;前端开发要操心后端的各种服务搭建和接口开发&#xff0c;这些琐碎而耗时的工作常常让人头大。但现在&#xff0c;你可以松一口气了&#xff0c;因为MemFir…

用eclipse做jsp网站柳州公司网站建设

激光扫描可以生成很多点云的数据集。并且&#xff0c;测量误差会导致一些稀疏的异常值使得结果更差。这使得局部点云特征估计变得更加的复杂&#xff0c;产生一些错误的值&#xff0c;使得点云的识别失败。有些不规则的数据可以通过数理统计的方法来消除。我们稀疏异样消除是以…

下载类网站模板九龙坡区建设二校有网站吗

1、简介 SPI(Serial Peripheral interface)串行外设接口。 特点: 高速:最大几十M,比如,AD9361的SPI总线速度可以达到40MHz以上全双工:主机在MOSI线上发送一位数据,从机读取它,而从机在MISO线上发送一位数据,主机读取它一主多从:主机产生时钟信号,通过片选引脚选择…

阿里巴巴做网站需要多少钱网站建设与设计实训总结

以新的 GMF 模型和专门的参与池奖励来开启 2024 年吧。 11 月 3 日&#xff0c;我们在香港全球创作者日上宣布&#xff0c;The Sandbox 已为所有创作者分配了100,000,000 SAND&#xff0c;将通过 GMF 进行分发。作为首次启动的建设者挑战&#xff0c;我们准备了专门的 SAND 参与…

从 Web 到 LLM,多入口、多链路的自动化威胁如何防护? - 详解

从 Web 到 LLM,多入口、多链路的自动化威胁如何防护? - 详解2025-09-22 20:45 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !impor…

学生管理系统案例初步分析报告

学生管理系统案例初步分析报告 目录学生管理系统案例初步分析报告功能讲解数据处理功能说明类功能讲解Main类Student类StudentManagementSystem类StudentManagementSystemTest类特殊类说明基本语法讲解 功能讲解 数据处…

【mysql】mysql5.6 版本修改用户的登录

在 MySQL 5.6 中,修改用户密码的语法与后续版本(如 MySQL 5.7+ 或 8.0)有所不同,主要使用 SET PASSWORD语句或直接更新 mysql.user表(不推荐,除非特殊情况): 方法 1:使用 SET PASSWORD语句(推荐)​​ ​语法…