Android 排序算法

时间复杂度

O = Big O

去除掉常数项、去除掉低价项、剩下最高阶项表示事件复杂度

选择排序算法 O(n*n)

排序算法

https://www.runoob.com/w3cnote/ten-sorting-algorithm.html

选择和冒泡排序

选择排序: 找到最小值和第一个交换; 没有稳定性

Sort.java

冒泡排序: 能保持稳定性

异或 = 无进位相加

EOR.java

1、特性

  • A^0 = A
  • A^A = 0

2、得出结论

  • 交换律 顺序无关
  • 结合律

同样内存位置 异或 会洗成0;

找出 数组中奇数次 的数

定义一个 eor 和数组所有的数 异或;

找出 数组中两种树是奇数次的数

定义一个 eor 和数组所有的数 异或;

找到 eor 中某一位上是 1 的表示 a 和 b 这两种数某一位上有一个是0 另一个是1;

定义 eor1 以后某一位上0 的数,最后得到 a 或者 b, 然后和 eor 异或得到另一个;

插入排序

Sort.java

0-1 向前看排序

0-2 向前看

0-n

有稳定性;

二分排序

找局部最小值

递归 归并排序

归并: 分割 partition 然后 merge 可以做到稳定性

master 公式求解时间复杂度

a、b、d 三个参数确定 就可以确定时间复杂度;

快速排序

做不到稳定性,

partition 的

堆排序

使用二叉树来进行排序

排序算法的稳定性,

同样值的个体之间,如果不因为排序而改变相对次序,就表示这个排序是稳定的,否则就不是

不具备稳定性的排序:

选择排序,快速排序,堆排序

稳定性排序:

冒泡排序,插入排序,归并排序,一切桶排序;

相关推荐
tankeven14 小时前
HJ164 太阳系DISCO
c++·算法
来自远方的老作者14 小时前
第7章 运算符-7.1 算术运算符
开发语言·数据结构·python·算法·算术运算符
white-persist15 小时前
【vulhub weblogic CVE-2017-10271漏洞复现】vulhub weblogic CVE-2017-10271漏洞复现详细解析
java·运维·服务器·网络·数据库·算法·安全
汀、人工智能16 小时前
[特殊字符] 第9课:三数之和
数据结构·算法·数据库架构·图论·bfs·三数之和
汀、人工智能16 小时前
[特殊字符] 第10课:接雨水
数据结构·算法·数据库架构·图论·bfs·接雨水
辰痕~16 小时前
数据结构-第一节课
数据结构
故事和你9116 小时前
蓝桥杯-2025年C++B组国赛
开发语言·软件测试·数据结构·c++·算法·职场和发展·蓝桥杯
py有趣16 小时前
力扣热门100题之合并区间
算法·leetcode
cpp_250116 小时前
P10108 [GESP202312 六级] 闯关游戏
数据结构·c++·算法·动态规划·题解·洛谷·gesp六级
Lzh编程小栈16 小时前
数据结构与算法之队列深度解析:循环队列+C 语言硬核实现 + 面试考点全梳理
c语言·开发语言·汇编·数据结构·后端·算法·面试