IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 选择排序 插入排序以及冒泡排序 -> 正文阅读

[数据结构与算法]选择排序 插入排序以及冒泡排序

选择排序

一种最简单的排序是这样的:首先,找到数组中最小的那个元素,其次,将它和数组的第一个元素交换位置.再次,在剩下的元素中找到最小的元素,将它与数组的第二个元素交换.如此往复,直到将整个数组排好序.代码比较简单.

public class Selection { //选择排序算法
 ?public static void main(String[] args) {
 ? ?int[] A = {9, 10, 7, 5, 4, 6, 2, 3, 2, 1, 0, 8};
 ? ?show(A);
 ? ?sort(A);
 ? ?assert isSorted(A);
 ? ?show(A);
  }
?
 ?public static void show(int[] A) {
 ? ?for (int i = 0; i < A.length; i++) {
 ? ? ?System.out.print(A[i] + " ");
 ?  }
 ? ?System.out.println();
  }
 ?public static void sort(int[] A) {
 ? ?for (int i = 0; i < A.length; i++) {
 ? ? ?int min = i; //最小的元素下标设置为每次外层(大)循环的那个值
 ? ? ?for (int j = i + 1; j < A.length; j++) {
 ? ? ? ?if (A[min] > A[j]) { //每次小循环都找到最小元素的下标
 ? ? ? ? ?min = j;
 ? ? ?  }
 ? ?  }
 ? ? ?exah(A, i, min); //将大循环的当前下标的值与其之后最小的值交换
 ?  }
  }
?
 ?public static void exah(int[] A, int i, int min) { //交换值函数
 ? ?int temp = A[i];
 ? ?A[i] = A[min];
 ? ?A[min] = temp;
  }
?
 ?public static boolean isSorted(int[] A) { //判断是否排序正确
 ? ?for (int i = 0; i < A.length; i++) {
 ? ? ?if (A[i] > A[i + 1])
 ? ? ? ?return false;
 ?  }
 ? ?return true;
  }
}

其实选择排序进行一个小总结便是,首先设置两层循环,小循环每循环一轮便发生一次大循环当前下标与小循环里找到的最小的未排序的元素的交换.

插入排序

插入排序与选择排序一样,当前索引左边的元素都是有序的,但它们的最终位置还不确定,为了给更小的元素腾出空间,它们可能会向左移动,当索引到达元素的最左边时,排序就已经完成了.

public class Insertion { //选择排序算法
 ?public static void main(String[] args) {
 ? ?int[] A = {9, 10, 7, 5, 4, 6, 2, 3, 2, 1, 0, 8};
 ? ?show(A);
 ? ?sort(A);
 ? ?assert isSorted(A);
 ? ?show(A);
  }
?
 ?public static void show(int[] A) {
 ? ?for (int i = 0; i < A.length; i++) {
 ? ? ?System.out.print(A[i] + " ");
 ?  }
 ? ?System.out.println();
  }
?
 ?public static void sort(int[] A) {
 ? ? ?for (int i = 1; i < A.length; i++) {
 ? ? ? ? ?for (int j = i; j > 0 && A[j - 1] > A[j]; j--) {
 ? ? ? ? ? ? ?exah(A, j - 1,j);
 ? ? ? ?  }
 ? ?  }
  }
?
 ?public static void exah(int[] A, int i, int min) { //交换值函数
 ? ?int temp = A[i];
 ? ?A[i] = A[min];
 ? ?A[min] = temp;
  }
?
 ?public static boolean isSorted(int[] A) { //判断是否排序正确
 ? ?for (int i = 0; i < A.length; i++) {
 ? ? ?if (A[i] > A[i + 1])
 ? ? ? ?return false;
 ?  }
 ? ?return true;
  }
}

当然,选择排序有很多种写法,但上述写法或许是递推方式中比较简单的.

冒泡排序

public class Bubble { //选择排序算法
 ?public static void main(String[] args) {//冒泡排序
 ? ?int[] A = {9, 10, 7, 5, 4, 6, 2, 3, 2, 1, 0, 8};
 ? ?show(A);
 ? ?sort(A);
 ? ?assert isSorted(A);
 ? ?show(A);
  }
?
 ?public static void show(int[] A) {
 ? ?for (int i = 0; i < A.length; i++) {
 ? ? ?System.out.print(A[i] + " ");
 ?  }
 ? ?System.out.println();
  }
?
 ?public static void sort(int[] A) {
 ? ? ?for (int i = 0; i < A.length-1; i++) {//第一层代表排序多少次,满足规律:循环次数等于数据元素个数-1
 ? ? ? ? ?for (int j = 0; j < A.length-i- 1; j++) {//第二层的两个值分别是0和大循环中间的值减去大循环当前下标
 ? ? ? ? ? ?if(A[j]>A[j+1])exah(A,j,j+1);
 ? ? ?  }
 ?  }
  }
?
 ?public static void exah(int[] A, int i, int min) { //交换值函数
 ? ?int temp = A[i];
 ? ?A[i] = A[min];
 ? ?A[min] = temp;
  }
?
 ?public static boolean isSorted(int[] A) { //判断是否排序正确
 ? ?for (int i = 0; i < A.length; i++) {
 ? ? ?if (A[i] > A[i + 1])
 ? ? ? ?return false;
 ?  }
 ? ?return true;
  }
}

以上三种都是最简单的排序算法,其平均时间复杂度都为O(n^2),下表尝试列出了这三种最简单排序的时间复杂度,空间复杂度,稳定性等等.

三种排序的比较

排序方法最快时间时间复杂度空间复杂度稳定性
选择排序O(n^2)O(n^2)O(1)不稳定
插入排序O(n)O(n^2)O(1)稳定
冒泡排序O(n)O(n^2)O(1)稳定
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-01-03 16:22:02  更:2022-01-03 16:22:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 11:09:33-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码