目录
百战程序员,全站22050+开发课程+文档 ,学习精选优质好课快人一步!观看视频 快捷键ALT+N

Python全系列 教程

3567个小节阅读:5931.4k

收藏
全部开发者教程

鸿蒙应用开发

C语言快速入门

JAVA全系列 教程

面向对象的程序设计语言

Python全系列 教程

Python3.x版本,未来主流的版本

人工智能 教程

顺势而为,AI创新未来

大厂算法 教程

算法,程序员自我提升必经之路

C++ 教程

一门通用计算机编程语言

微服务 教程

目前业界流行的框架组合

web前端全系列 教程

通向WEB技术世界的钥匙

大数据全系列 教程

站在云端操控万千数据

AIGC全能工具班

A

A A

White Night

阅读(150)
赞(0)

冒泡排序

image-20220906170639809

冒泡排序是一种简单的排序算法

算法思路

  • 比较相邻的元素。如果第1个比第2个大,就交换它们两个;

  • 对每一对相邻元素做同样的工作,从开始第1对到结尾的最后1对,这样在最后的元素应该会是最大的数;

  • 针对所有的元素重复以上的步骤,除了最后一个;

  • 持续每次对越来越少的元素重复上面的步骤,直到没有任何1对数字需要比较

冒泡排序思路图

举例

image-20220914144117489

代码

特性

  • 时间复杂度为 $O( n^2 )$、自适应排序:各轮"冒泡"遍历的数组长度依次为 n-1、n-2、...... 2、1 ,总和为$ (n-1)n/2 $。在引入 flag 优化后,最佳时间复杂度可达到 $O(n)$

  • 空间复杂度为$ O(1) $、原地排序:指针 i 和 j 使用常数大小的额外空间

  • 稳定排序:由于在"冒泡"中遇到相等元素不交换

实时效果反馈

1. 关于冒泡排序算法,说法对的是?

A 冒泡排序需要反复比较相邻的元素

B 冒泡排序只能从小到大排序

C 冒泡排序的数据总个数有限

答案

1=>A

北京市昌平区回龙观镇南店村综合商业楼2楼226室

©2014-2023 百战卓越(北京)科技有限公司 All Rights Reserved.

京ICP备14032124号-2