上篇:《排序算法的奇妙世界:如何让数据井然有序?》

上篇:《排序算法的奇妙世界:如何让数据井然有序?》

个人主页:strive-debug

排序算法精讲:从理论到实践

 一、排序概念及应用


 1.1 基本概念  


**排序**:将一组记录按照特定关键字(如数值大小)进行递增或递减排列的操作。
 1.2 常见排序算法分类

 
- **简单低效型**:直接插入排序、冒泡排序、选择排序  
- **高效优化型**:希尔排序、快速排序、归并排序、堆排序  

---

二、基础排序算法实现
 2.1 插入排序家族
 2.1.1 直接插入排序


核心思想:将待排元素逐个插入已有序序列中。  
void InsertSort(int* arr, int n) { for (int i = 0; i < n - 1; i++) { int end = i; int tmp = arr[end + 1]; while (end >= 0) { if (arr[end] > tmp) { arr[end + 1] = arr[end]; end--; } else { break; } } arr[end+1] = tmp; } }

我的理解(如图所示):

**特性分析**:  
 **接近有序时效率高**  
 时间复杂度:O(N^2)
 空间复杂度:O(1)
 2.1.2 希尔排序(优化版插入排序)


**优化策略**:通过分组增量(gap)预排序逐步逼近全局有序。  
void ShellSort(int* arr, int n) { int gap = n; while (gap > 1) { //推荐写法:除3 gap = gap / 3 + 1; for (int i = 0; i < n - gap; i++) { int end = i; int tmp = arr[end + gap]; while (end >= 0) { if(arr[end] > tmp) { arr[end + gap] = arr[end]; end -= gap; } else { break; } } arr[end + gap] = tmp; } } }

我的理解(如图所示):

 

**特性分析**:  
 **突破O(N^2)的时间瓶颈**  
 时间复杂度:约 O(N^{1.3}) 
 空间复杂度:O(1)

---

2.2 选择排序


直接选择排序
**核心思想**:每轮选取最小/最大值固定到序列两端。  

void SelectSort(int* arr, int n) { int begin = 0, end = n - 1; while (begin < end) { int maxi = begin; int mini = begin; for (int i = begin; i <= end; i++)//end=n-1,不是n { if (arr[i] > arr[maxi]) { maxi = i;//不是arr[i] } if (arr[i] < arr[mini]) { mini = i; } } //要先判断如果maxi在开头的话,就是发生来回替换的情况 if (maxi == begin) { maxi = mini; } //循序不能乱 Swap(&arr[mini], &arr[begin]); Swap(&arr[maxi], &arr[end]); //不要忘记让end和begin,这是一个while循环 end--; begin++; } }

我的理解(如图所示):

---

 2.3 交换排序


冒泡排序
经典实现+提前终止优化:  
 

void BubbleSort(int* arr, int n) { int exchange = 0; for (int i = 0; i < n; i++) { for (int j = 0; j < n - 1 - i; j++) { if (arr[j] > arr[j + 1]) { exchange = 1; Swap(&arr[j], &arr[j + 1]); } } if (exchange == 0) { break; } } }
**适用场景**:  
 **教学演示为主,实际工程较少使用**  
 时间复杂度:O(N^2)  

---

三、算法对比总结

| 算法         | 时间复杂度       | 空间复杂度 | 稳定性 | 适用场景             |
|--------------|------------------|------------|--------|------------------------|
| 直接插入排序 |O(N^2)      | O(1)   | ✔️      | 小规模或接近有序数据   |
| 希尔排序        |O(N^{1.3}) |O(1)    | ✖️      | 中等规模数据                 |
| 选择排序        |O(N^2)      | O(1)   | ✖️      | 教学演示                         |
| 冒泡排序        |O(N^2)      | O(1)   | ✔️      | 理解交换思想                 |

---

 **四、下篇预告**
**《高阶排序算法:分治思想与性能突破》**  
-  **快速排序的三种分区策略**  
-  **归并排序的递归与非递归实现**  
-  **堆排序与优先队列的深度关联**

---

Read more

鸿蒙金融理财全栈项目——风险控制、合规审计、产品创新

鸿蒙金融理财全栈项目——风险控制、合规审计、产品创新

《鸿蒙APP开发从入门到精通》第18篇:鸿蒙金融理财全栈项目——风险控制、合规审计、产品创新 📊🛡️🚀 内容承接与核心价值 这是《鸿蒙APP开发从入门到精通》的第18篇——风险控制、合规审计、产品创新篇,100%承接第17篇的金融理财项目架构,并基于金融场景的风险控制、合规审计、产品创新要求,设计并实现鸿蒙金融理财全栈项目的风险控制、合规审计、产品创新功能。 学习目标: * 掌握鸿蒙金融理财项目的风险控制设计与实现; * 实现风险评估、风险监控、风险预警; * 理解合规审计在金融场景的核心设计与实现; * 实现合规检查、合规审计、合规报告; * 掌握产品创新在金融场景的设计与实现; * 实现产品创新、产品优化、产品推广; * 优化金融理财项目的用户体验(风险控制、合规审计、产品创新)。 学习重点: * 鸿蒙金融理财项目的风险控制设计原则; * 合规审计在金融场景的应用; * 产品创新在金融场景的设计要点。 一、 风险控制基础 🎯 1.1 风险控制定义 风险控制是指对金融理财项目的风险进行识别、评估、监控、

By Ne0inhk
Flutter 三方库 fast_rx 的鸿蒙化适配指南 - 实现极致性能的响应式组件状态管理、支持轻量级 Rx 变量订阅与端侧实时 UI 自动刷新实战

Flutter 三方库 fast_rx 的鸿蒙化适配指南 - 实现极致性能的响应式组件状态管理、支持轻量级 Rx 变量订阅与端侧实时 UI 自动刷新实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 fast_rx 的鸿蒙化适配指南 - 实现极致性能的响应式组件状态管理、支持轻量级 Rx 变量订阅与端侧实时 UI 自动刷新实战 前言 在进行 Flutter for OpenHarmony 开发时,选择合适的状态管理框架是决定应用架构质量的关键。如果你追求类似 GetX 的简洁响应式体验,但又希望极度轻量、不侵入路由管理,那么 fast_rx 是你的不二之选。它专为极速订阅和最小化刷新设计。本文将探讨如何在鸿蒙端利用该库构建高效的响应式生态。 一、原直观解析 / 概念介绍 1.1 基础原理 fast_rx 采用了“观察者模式”的极致语义化实现。通过包装基础类型(如 Int, String,

By Ne0inhk
狂涨 17.8K star!!再见手动运维,这个强大的任务神器青龙面板太爽了!

狂涨 17.8K star!!再见手动运维,这个强大的任务神器青龙面板太爽了!

文章目录 * **前言:** * 1、关于青龙面板 * 2、部署安装 * 3、简单使用青龙面板 * 4、介绍以及安装cpolar * 5、配置公网地址 * 5、配置固定二级子域名公网地址 * 6. 总结 前言: 各位小伙伴们,你们是不是经常遇到这样的困扰:每天定时需要跑个脚本,比如薅羊毛、自动签到、数据抓取… 每次都得守在电脑前,生怕错过最佳时机?或者凌晨惊醒,默默打开电脑执行脚本? 别再自虐了! 今天,我就要给大家推荐一个神器——青龙面板!它能帮你搞定这些重复性工作,让你彻底告别熬夜脚本,从此解放双手,躺着就能收收益! 1、关于青龙面板 青龙面板,简单来说,就是个自动化任务的管家。 它可以帮你定时执行各种脚本,比如 JavaScript、Python、Shell 等。 想象一下,你只需要设定好规则,它就能自动帮你搞定一切,是不是超级省心?

By Ne0inhk
Flutter for OpenHarmony: Flutter 三方库 google_maps 在鸿蒙应用中嵌入全球地图服务的架构实践(跨平台地图方案库)

Flutter for OpenHarmony: Flutter 三方库 google_maps 在鸿蒙应用中嵌入全球地图服务的架构实践(跨平台地图方案库)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在进行 OpenHarmony 的全球化应用开发时,地图服务是出海项目绕不开的核心组件。对于已经在海外市场成熟运行、深度依赖 Google 地图生态的 Flutter 应用,如何将现有的地图逻辑迁移或适配到鸿蒙平台,是许多出海大企关注的焦点。 虽然鸿蒙在国内市场主要使用高德或百度地图,但在处理“全球一张图”需求时,google_maps 相关的 Flutter 插件及其底层的 Dart 模型定义,依然是定义地理围栏、标记点(Marker)和轨迹绘制的标准参考。本篇将探讨如何在鸿蒙跨平台架构中,平衡 Google 地图的通用逻辑与鸿蒙的原生渲染。 一、跨平台地图适配架构 在鸿蒙适配中,我们通常采用“统一接口层,分平台实现”的策略。 模型转换 适配层 Flutter 业务层 (Dart) 地图抽象层

By Ne0inhk