Java排序

Java 常用排序方法(直接可用)

  1. 数组自带排序(最简单)

import java.util.Arrays;

public class Main {

public static void main(String\[\] args) {

int\[\] arr = {5, 2, 9, 1, 5, 6};

// 升序排序

Arrays.sort(arr);

System.out.println(Arrays.toString(arr));

}

}

  1. 集合排序(List)

import java.util.ArrayList;

import java.util.Collections;

public class Main {

public static void main(String\[\] args) {

ArrayList<Integer> list = new ArrayList<>();

list.add(3);

list.add(1);

list.add(4);

Collections.sort(list);

System.out.println(list);

}

}

  1. 冒泡排序(手写基础)

public static void bubbleSort(int\[\] arr) {

int n = arr.length;

for (int i = 0; i < n-1; i++) {

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

if (arrj > arrj+1) {

int temp = arrj;

arrj = arrj+1;

arrj+1 = temp;

}

}

}

}

  1. 选择排序

public static void selectionSort(int\[\] arr) {

int n = arr.length;

for (int i = 0; i < n-1; i++) {

int min = i;

for (int j = i+1; j < n; j++) {

if (arrj < arrmin) min = j;

}

int temp = arrmin;

arrmin = arri;

arri = temp;

}

}

  1. 插入排序

public static void insertionSort(int\[\] arr) {

int n = arr.length;

for (int i = 1; i < n; i++) {

int key = arri;

int j = i - 1;

while (j >= 0 && arrj > key) {

arrj+1 = arrj;

j--;

}

arrj+1 = key;

}

}

  1. 快速排序(常用高效)

public static void quickSort(int\[\] arr, int left, int right) {

if (left >= right) return;

int i = left, j = right, pivot = arrleft;

while (i < j) {

while (i < j && arrj >= pivot) j--;

arri = arrj;

while (i < j && arri <= pivot) i++;

arrj = arri;

}

arri = pivot;

quickSort(arr, left, i-1);

quickSort(arr, i+1, right);

}

相关推荐
未秃头的程序猿7 小时前
Java 26正式发布!这3个新特性,让代码量直接减半
java·后端·面试
用户298698530148 小时前
Word 文档文本查找与替换的 Java 实现方案
java·后端
阿哉8 小时前
Nacos 服务发现源码:藏在背后的两套事件机制,90%的人只讲了一半
java
咖啡八杯8 小时前
GoF设计模式——命令模式
java·设计模式·架构
AI人工智能_电脑小能手8 小时前
【大白话说Java面试题 第125题】【并发篇】第25题:说说 Java 线程的中断机制
java·后端·面试
Java内核笔记8 小时前
Spring Security 源码解析(六)无状态 JWT 实践:Session 共享与自定义过滤器
java·后端
荣码8 小时前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python
唐青枫10 小时前
Java 虚拟线程实战指南:从 Thread API 到 Spring Boot 高并发应用
java
白鲸开源1 天前
Apache SeaTunnel Zeta Engine 的 Basic Auth 是怎么工作的?
java·vue.js·github
白鲸开源1 天前
一文读懂DolphinScheduler插件机制:如何轻松扩展任务类型与数据源
java·架构·github