首页 > 编程语言 >软件设计师:排序算法总结

软件设计师:排序算法总结

时间:2024-11-07 16:16:31浏览次数:3  
标签:26 58 54 37 算法 75 设计师 排序

一、直接插入

排序方式:从第一个数开始,拿两个数比较,把后面一位跟前面的数比较,把较小的数放在前面一位

二、希尔

排序方式:按“增量序列(步长)”分组比较,组内元素比较交换

 假设初始关键字:48    37    64    96    75    12    26    58    54    3,有当增量序列为“5,3,1”时,希尔插入排序过程如下

第一组:48和12比较,48比12大则此时交换位置后最新排序为:12,37,64,96,75,48,26,58,54,3
                                    
第二组:在上一组排序结果的基础上,37和26比较,37比26大则此时交换位置后最新排序为:12,26,64,96,75,48,37,58,54,3
                                    
第三组:在上一组排序结果的基础上,64和58比较,64比58大则此时交换位置后最新排序为:12,26,58,96,75,48,37,64,54,3
                                
第四组:在上一组排序结果的基础上,96和54比较,96比54大则此时交换位置后最新排序为:12,26,58,54,75,48,37,64,96,3    
                                
第五组:在上一组排序结果的基础上,75和3比较,75比3大则此时交换位置后最新排序为:12,26,58,54,3,48,37,64,96,75

第一组:12,54,37,75按从小到大顺序排列交换位置后最新排序为:12,26,58,37,3,48,54,64,96,75    
                                                                                
第二组:在上一组排序结果的基础上,26,3,64按从小到大顺序排列交换位置后最新排序为:12,3,58,37,26,48,54,64,96,75
                                                                                
第三组:在上一组排序结果的基础上,58,48,96按从小到大顺序排列交换位置后最新排序为:12,3,48,37,26,58,54,64,96,75

三、简单选择

排序方式:每一次排序都把当前最小的元素拿出来
初始关键词:1,5,2,7,4

四、堆排序

排序方式:
1.先把元素按照完全二叉树的形式建成一个堆
2.再按大根堆(左<根>右)排序
3.从下往上调整,直至全部满足左<根>右
4.把堆顶元素跟堆底最后一个元素交换,继续调整,直至全部满足左<根>右

五、冒泡排序

排序方式:从第一个元素开始,前面一个元素跟后面一个元素两两比较,前面大于后面则交换

六、快速排序

排序方式:
1.从后往前找第一个小于关键字p(初始序列中第一个元素,且不会变更)
2.这里用i代表最前,j代表最后
3.当j>p时则j往前移一位(j--),当j<p时,把j的值赋值给i,这时候再从最前面开始找
4.当i<p时,i往后挪一位(i++)
5.当i>p时,把i的值赋值给j
6.循环以上步骤直到i=j,则把p的值赋值给i=j这个位置

七、归并排序

排序方式:假设有n个元素( 2,1,4,7,3,5,6,2);则n=8,每次按n/2分组排序

标签:26,58,54,37,算法,75,设计师,排序
From: https://blog.csdn.net/2401_83100107/article/details/143597428

相关文章

  • 揭秘:Java加盐加密算法,保护你的数据安全!
    加盐加密算法是一种在密码处理中广泛使用的技术,通过为密码添加一个随机值(称为“盐”)来增加密码的复杂性和安全性。下面将详细介绍加盐加密算法的概念、实现步骤以及代码示例:加盐加密算法概念加盐加密算法:通过引入随机生成的盐值与用户密码组合后进行哈希运算,以增强密码的安......
  • 街面环卫算法视频分析服务器流动商贩实时视频流分析边缘计算技术简介
    在当今数字化时代,实时视频流分析已成为推动智能监控、智慧城市和自动驾驶等前沿领域发展的关键技术。它通过深度挖掘视频内容,提供了前所未有的洞察力和即时反应能力。然而,这一技术面临着计算负载高、带宽需求大和对延迟的严格要求等挑战,这些挑战限制了其在传统云计算架构中的应用......
  • AI智能分析视频分析网关室内消防逃生通道占用检测算法详解
    在公共安全领域,特别是在火灾等紧急状况下,确保消防逃生通道的畅通对于快速疏散人群至关重要。但是,由于多种原因,这些逃生通道常常被堵塞或占用,极大地增加了疏散时的风险。为了应对这一挑战,人工智能驱动的室内消防逃生通道占用视频分析网关应运而生,成为提高消防安全水平的关键工具。......
  • 路径分析算法—基于Floyd算法的路径分析
    原文链接:路径分析算法—基于Floyd算法的路径分析–每天进步一点点Floyd算法是一种用于在已知给定的加权图中求多源点之间最短路径的算法。它与Dijkstra算法类似,不同点在于Dijkstra计算的是单源点之间的最短路径。Floyd算法是在数学建模领域和日常工作中使用频率较高的路径分......
  • 路径分析算法—基于A*算法的路径搜索
    原文链接:路径分析算法—基于A*算法的路径搜索–每天进步一点点A*算法擅长解决静态路径中最短路径问题,而又不同于Dijkstra算法和Floyd算法,该算法综合了广度优先搜索(BreadthFirstSearch)和Dijkstra算法的优点:在进行启发式搜索提高算法效率的同时,可以保证找到一条最优路径(基于评......
  • HintonLeCunBengio:AI算法的奠基者
    深度学习、神经网络、卷积神经网络、循环神经网络、GeoffreyHinton、YannLeCun、YoshuaBengio1.背景介绍人工智能(AI)的蓬勃发展,离不开深度学习的革命性突破。深度学习,作为机器学习的一个分支,通过构建多层神经网络来模拟人类大脑的学习机制,取得了令人瞩目的成就。而推......
  • 深入理解PPO算法:从原理到实现
    目录1.引言2.PPO算法的背景3.PPO算法的核心思想4.PPO算法的实现步骤 4.1PPO代码实现 4.2代码说明5.为什么PPO效果如此出色? 5.1PPO的优势函数与GAE 5.2PPO的变体:PPO-Clip和PPO-KL6.PPO算法的应用场景7.总结1.引言        在强化学习领域,PPO(P......
  • 【KMP算法】
    目录BF算法KMP算法BF算法F算法,即暴力(BruteForce)算法,是普通的模式匹配算法,BF算法的思想就是将目标串S的第一个字符与模式串T的第一个字符进行匹配,若相等,则继续比较S的第二个字符和T的第二个字符;若不相等,则比较S的第二个字符和T的第一个字符,依次比较下去,直到得出最后......
  • α-shape算法曲面重建
    目录1原理介绍α-shape的基础概念数学公式推导2.1外接圆半径2.2根据α参数筛选三角形2.3构建α-shape2.4参数调整与优化3α-shape的构建步骤4示例代码        取点云的凹边界是计算几何中的一个经典问题。凹边界与凸边界不同,它能捕捉到数据的细......
  • Java深度优先搜索(DFS)算法实现
    标题:Java深度优先搜索(DFS)算法实现引言:深度优先搜索(Depth-FirstSearch,DFS)是一种常用的图遍历算法,它通过递归地遍历图中的每个顶点,来寻找特定的路径或解决某些问题。本篇博客将介绍如何用Java语言实现深度优先搜索算法。算法思想:深度优先搜索算法的基本思想是先访问一个......