冒泡排序 选择排序 插入排序

package com.nobody.sort;

/**

  • @author Mr.nobody

  • @Description 插入排序

  • @date 2020/9/5

*/

public class Code01_InsertionSort {

public static void insertionSort(int[] arr) {

// 数组为空,或者数组长度小于2就没必要操作

if (null == arr || arr.length < 2) {

return;

}

// 依次让00,01,02,...,0n-1区间的数有序

// 则需要每次让1,2,3,...,n-1位置上的数与左边的所有数据进行比较

// 每次比较,如果小于左边的数就进行交换,直到不小于左边的数

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);

}

}

}

// 采用异或操作交换两个数

private static void swap(int[] arr, int i, int j) {

arr[i] = arr[i] ^ arr[j];

arr[j] = arr[i] ^ arr[j];

arr[i] = arr[i] ^ arr[j];

}

}

<>选择排序

===============================================================

package com.nobody.sort;

/**

  • @author Mr.nobody

  • @Description 选择排序

  • @date 2020/9/5

*/

public class Code02_SelectionSort {

public static void selectionSort(int[] arr) {

// 数组为空,或者数组长度小于2就没必要操作

if (null == arr || arr.length < 2) {

return;

}

// 每次从位置为0,1,2,...,n-1开始,与后面的数比较,

// 找出第i小的数的位置,将其数与i位置的数交换

for (int i = 0; i < arr.length - 1; i++) {

int minIndex = i;

for (int j = i + 1; j < arr.length; j++) {

minIndex = arr[j] < arr[minIndex] ? j : minIndex;

}

if (i != minIndex) {

swap(arr, i, minIndex);

}

}

}

// 采用异或操作交换两个数

private static void swap(int[] arr, int i, int j) {

arr[i] = arr[i] ^ arr[j];

arr[j] = arr[i] ^ arr[j];

arr[i] = arr[i] ^ arr[j];

}

}

<>冒泡排序

===============================================================

package com.nobody.sort;

/**

  • @author Mr.nobody

  • @Description 冒泡排序

  • @date 2020/9/5

*/

public class Code03_BubbleSort {

public static void bubbleSort(int[] arr) {

// 数组为空,或者数组长度小于2就没必要操作

if (null == arr || arr.length < 2) {

return;

}

// 每次从左边第一个元素开始,依次和后面的数据比较,大于后面数据就交换,

// 每次与后面的比较的次数为n-1,n-2,...1次,每次都把大数放在最右边

for (int i = arr.length - 1; i > 0; i--) {

for (int j = 0; j < i; j++) {

if (arr[j] > arr[j + 1]) {

swap(arr, j, j + 1);

}

}

}

}

// 采用异或操作交换两个数

private static void swap(int[] arr, int i, int j) {

arr[i] = arr[i] ^ arr[j];

arr[j] = arr[i] ^ arr[j];

arr[i] = arr[i] ^ arr[j];

}

}

<>测试

=============================================================

package com.nobody.sort;

import java.util.Arrays;

/**

  • @author Mr.nobody

  • @Description

  • @date 2020/9/5

*/

public class Main {

public static void main(String[] args) {

int[] arr = {1, 5, 3, 2, 8, 10, 11, 3, 4, 0};

System.out.print("原始数组:");

Arrays.stream(arr).forEach(e -> System.out.print(e + " "));

System.out.println();

Code01_InsertionSort.insertionSort(arr);

System.out.print("插入排序:");

Arrays.stream(arr).forEach(e -> System.out.print(e + " "));

System.out.println();

相关推荐
潇I洒2 分钟前
若依4.8.1打包war后在Tomcat无法运行,404报错的一个解决方法
java·tomcat·ruoyi·若依·404
kyle~19 分钟前
排序---插入排序(Insertion Sort)
c语言·数据结构·c++·算法·排序算法
Funcy28 分钟前
XxlJob 源码分析05:执行器注册流程
java
Boop_wu29 分钟前
[数据结构] 队列 (Queue)
java·jvm·算法
无敌的神原秋人33 分钟前
关于Redis不同序列化压缩性能的对比
java·redis·缓存
hn小菜鸡1 小时前
LeetCode 3643.垂直翻转子矩阵
算法·leetcode·矩阵
Chan161 小时前
JVM从入门到实战:从字节码组成、类生命周期到双亲委派及打破双亲委派机制
java·jvm·spring boot·后端·intellij-idea
招风的黑耳2 小时前
Java生态圈核心组件深度解析:Spring技术栈与分布式系统实战
java·spring·wpf
ゞ 正在缓冲99%…2 小时前
leetcode101.对称二叉树
算法