当前位置: 首页 > news >正文

class 004 选择 冒泡 插入排序

我感觉这个真是没有什么好讲的, 这个是比较简单的, 感觉没有什么必要写一篇博客, 而且这个这么简单的排序问题肯定有人已经有写好的帖子了, 肯定写的比我好, 所以我推荐大家直接去看“左程云”老师的讲解就很好了, 一定是能看懂的, 要是用文字形式再写一遍, 反而有点画蛇添足了. 这里就将三个排序的代码写上.

这三个排序算法中唯一需要注意的是:插入排序, 这个在小数据量的时候排序的速度是非常快的, 一般认为数组长度在 10 ~ 50 之间, 插入排序的效率是非常快的. 后续学习的希尔排序, Tim 排序都有插入排序的参与. Tim 排序是 Python 和 Java 中内置的排序方式, 有兴趣可以去了解一下.

这里就直接附上对应的链接, 大家自己直接去看吧!!!

算法讲解004【入门】选择、冒泡、插入排序-左程云-算法通关-哔哩哔哩视频 (bilibili.com)

在这里插入图片描述

交换的方法实现:

public static void swap(int[] arr, int i, int j) {  int tmp = arr[i];  arr[i] = arr[j];  arr[j] = tmp;  
}

1. 冒泡排序

public static void bubbleSort(int[] arr) {  if (arr == null || arr.length < 2) {  return;  }  for (int i = 0; i < arr.length - 1; i++) {  for (int j = 0; j < arr.length - i - 1; j++) {  if (arr[j] > arr[j + 1]) {  swap(arr, j, j + 1);  }  }  }  
}

2. 选择排序

public static void selectionSort(int[] arr) {  if (arr == null || arr.length < 2) {  return;  }  for (int minIndex, i = 0; i < arr.length - 1; i++) {  minIndex = i;  for (int j = i + 1; j < arr.length; j++) {  if (arr[j] < arr[minIndex]) {  minIndex = j;  }  }  swap(arr, i, minIndex);  }  
}

3. 插入排序

public static void insertionSort(int[] arr) {  if (arr == null || arr.length < 2) {  return;  }  for (int i = 1; i < arr.length; i++) {  for (int j = i - 1; j >= 0 && arr[j] > arr[j + 1]; j--) {  swap(arr, j, j + 1);  }  }  
}

http://www.mrgr.cn/news/43449.html

相关文章:

  • 第十篇——数列和级数(三):藏在利息和月供里的秘密
  • 【深度学习】— 多层感知机介绍、 隐藏层、从线性到非线性、线性模型的局限性
  • RTX4060安装nvidia显卡驱动
  • 【韩顺平Java笔记】第7章:面向对象编程(基础部分)【227-261】
  • 解决Vue应用中遇到路由刷新后出现 404 错误
  • 计算机网络——http和web
  • 在 MySQL 中处理和优化大型报告查询经验分享
  • 定义类方法的错误总结
  • 《CUDA编程》4.CUDA程序的错误检测
  • LeetCode hot100---二叉树专题(C++语言)
  • 十二、血条UI
  • 0-1背包问题
  • Windows 11 24H2 v26100.1742 官方简体中文版
  • 【图论】树剖(上):重链剖分
  • ChatGPT Canvas:交互式对话编辑器
  • Matlab编程示例24:freexyn在b站的读取手写体mnist数据集的matlab代码
  • [NeurIPS 2022] STaR: Bootstrapping Reasoning With Reasoning
  • 计算机视觉算法知识详解(含代码示例)
  • Koa2项目实战1(项目搭建)
  • 【Mybatis篇】Mybatis的关联映射详细代码带练 (多对多查询、Mybatis缓存机制)