排序法-冒泡排序法

java 复制代码
package com.jianstudy.array;
import java.util.Arrays;//导入Arrays工具类
public class ArrayDemo09 {
    public static void main(String[] args) {
       int [] array ={1,6,7,8,9,0,2365,36,78,77,78,5,33,7,85};
        sortMine(array);//调用自己写的排序方法
        for(int i : array){//使用增强for循环打印数组 for each循环
            System.out.print(i+" ");
        }
        //System.out.println(Arrays.toString(array));//使用Arrays类工具打印
    }
    //冒泡排序
    public static int[] sortMine(int[] a) {
     /*
        升序降序看要求
        1. 比较数组中,两个相邻的元素,如果前后项不等就交换他们的位置
        2. 每一次比较都会产生一个最大或者最小的数
        3. 下一轮则可以少一次排序
        4. 依次循环直至结束
         */
        int temp = 0;//两项交换时的中转项
        //升序 从小到大排序
        for (int i = 0; i < a.length-1; i++) {//外层循环 数组有几项 就循环n-1次
        /*
        1. 外层循环:i < a.length - 1
	含义:

	外层循环控制排序的轮数。

	对于一个长度为 n 的数组,最多需要 n - 1 轮排序才能确保数组完全有序。

	为什么是 i < a.length - 1?

	每一轮排序会将当前未排序部分的最大值"冒泡"到正确的位置。

	经过 n - 1 轮后,剩下的最后一个元素已经是最小的,无需再比较。
        */
            for (int j = 0; j < a.length-1-i; j++) {//内存循环 比较前后项大小 有大小就交换他们的位置
            /*
            2. 内层循环:j < a.length - 1 - i
	含义:
	
	内层循环负责在每一轮中比较相邻元素并交换。
	
	a.length - 1 - i 表示每一轮需要比较的范围。

	为什么是 j < a.length - 1 - i?

	每一轮排序后,最大的元素会被放到数组的末尾,因此下一轮无需再比较已经排序好的部分。

	i 表示已经排序好的元素个数,因此每一轮需要比较的范围逐渐缩小。
	*/
                if (a[j + 1] < a[j]) {//升序 比较两项 如果后项比前项小就交换前后项的位置 降序就是把小于号改成大于号
                    temp = a[j + 1];//先把后项先赋给中转项
                    a[j + 1] = a[j];//给然后把前项赋后项
                    a[j] = temp;//最后把存放后项的中转项赋给前项
                }
            }
        }
        return a;
    }
}

int \[\] array ={1,6,7,8,9,0,2365,36,78,77,78,5,33,7,85};

相关推荐
数智工坊7 小时前
机器人运动控制:采样、优化与学习三大流派深度对比与实战
android·学习·机器人
ZC跨境爬虫7 小时前
跟着 MDN 学JavaScript day_7:数学运算与逻辑判断实战测试
开发语言·前端·javascript·学习·ecmascript
fangdengfu1238 小时前
ES分析系统各个服务日志占用量
java·前端·elasticsearch
云烟成雨TD8 小时前
Spring AI 1.x 系列【51】可观测性技术选型
java·人工智能·spring
星越华夏8 小时前
ESP32-CAM图像传输项目说明文档
java·后端·struts·esp32
Jinkxs9 小时前
Java 跨域14-Java 与区块链(Hyperledger)集成
java·开发语言·区块链
晨曦中的暮雨10 小时前
Golang速通(Javaer版)
java·开发语言·后端·golang
七老板的blog10 小时前
当 Spring StateMachine 遇见大模型:构建工业级 AI 写作流水线
java·人工智能·spring
MartinYeung510 小时前
[论文学习]隐私保护联邦特徵选择与差分隐私的的工程实践框架
学习
qeen8710 小时前
【C++】类与对象之类的默认成员函数(二)
android·c语言·开发语言·c++·笔记·学习