| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> c++算法大全——(二)排序(1) -> 正文阅读 |
|
[数据结构与算法]c++算法大全——(二)排序(1) |
系列文章目录1.高精度的计算 2.排序(1) 目录一、什么是排序? ? ? ? 排序就是将一个无序的数列按照一定规则排列成一个有序数列,常见的排序规则有从小到大和从大到小两种。数列0、32、53、12、34、2、1、90按常用规则排序后为:
二、用什么方法排序? ? ? ? 目前常用的排序方法有插入排序、选择排序、冒泡排序等八大排序,这些排序时间复杂度各异。下面,我将列举这八大排序的时间、空间复杂度:
? ? ? ? 本章将会讲解基本一些的排序方法,其他的将会在以后讲解。 三、怎样排序? ? ? ? 接下来我会详细讲解一些排序算法,所有代码均为从小到大的排序代码。 3.1 冒泡排序排序特点:每一个数值都会像水底的泡泡一样不断上升,直到到达合适的位置。 排序原理:就近比较两个数的值,如果前数大于后数,则交换两数,使数列逐渐变得有序。 代码示例:
输入样例:
输出效果截图: 算法评估:时间复杂度为O(n^2),有些大。 3.2 插入排序排序特点:每次交换两个的值,对于求得最少交换次数有一定帮助。 排序原理:从最前一个数向后枚举,与后面的数进行比较 代码示例:
输入样例:
输出效果截图: 算法评估:?时间复杂度为O(n^2),有些大,但是对于求得最少交换次数有一定帮助。 3.3 系统函数排序原理:运用快速排序的优化,使得其在快排的基础上更加稳定。 函数原型:
前两个参数是必要的,最后一个可有可无,代码示例:
算法评估:时间复杂度低,适用性强。 总结? ? ? ? 排序算法千千万,唯有sort万人迷。插入排序时间慢,希尔排序不稳定 。 ? ? ? ? 快速排序虽然快,但是要求特别高。堆排归排固然好,理解起来可复杂。 ? ? ? ? 再见! |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 21:24:06- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |