冒泡排序(经典)

文章目录

冒泡排序

相邻的两个元素的比较,每次选出一个最大值。

总共由两次循环,外层循环为总共需要比较多少次,一般全部无序的数组,需要比较该数组的长度的值。

内层循环,每一次比较需要比较多少次,每一次都比上一次减少一次的次数。

注意点:

1.优化的 flag 是为了减少排序次数,如果在一次比较中都没有交换数据,那么这个数组就是有序的。

2.i 的初始化为 0,是j的初始化也为 0,注意 j 的终止条件为:j < arr.length - i - 1,是为了防止越界。

详细代码

java 复制代码
public class BubbleSort {

    public static void main(String[] args) {
    //初始化数组
        int[] arr = {1, 5, 3, 456, 5, 6, 7, 13, 9, 100};
        System.out.println("排序前:" );
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }
        BubbleSort bubbleSort = new BubbleSort();
        bubbleSort.BubbleSortMethod(arr);
        System.out.println("排序后:" );
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }
    }

    public int[] BubbleSortMethod(int arr[]){

        int temp;

        boolean flag = true;//优化的flag是为了减少排序次数,如果在一次比较中都没有交换数据,那么这个数组就是有序的。

        for (int i = 0; i < arr.length; i++){
            for (int j = 0; j < arr.length  - i - 1; j++) { //j < arr.length  - i - 1,是为了防止越界
                if (arr[j] > arr[j+1]) {
                    temp = arr[j+1];
                    arr[j+1] = arr[j];
                    arr[j] = temp;

                    flag = false;
                }
            }
            if (flag){
                break;
            }
        }

        return arr;
    }
}

我是小辉,24 届毕业生。当下是找工作ing,欢迎关注,持续分享。

相关推荐
一个不知名程序员www6 分钟前
算法学习入门---前缀和(C++)
c++·算法
jackzhuoa19 分钟前
Rust API 设计的零成本抽象原则:从语言基石到工程实践
算法·rust
yuuki23323327 分钟前
【数据结构】双向链表的实现
c语言·数据结构·后端
我不是彭于晏丶1 小时前
238. 除自身以外数组的乘积
数据结构·算法
兮山与1 小时前
算法25.0
算法
爱编程的鱼1 小时前
想学编程作为今后的工作技能,学哪种语言适用性更强?
开发语言·算法·c#·bug
代码雕刻家1 小时前
1.6.课设实验-数据结构-栈、队列-银行叫号系统2.0
c语言·数据结构
yq14682860901 小时前
C (统计二进制中“1“的个数)
c语言·开发语言·算法
被AI抢饭碗的人1 小时前
算法题(254):灾后重建
算法·leetcode·职场和发展
深度学习机器2 小时前
RAG的另一种思路,基于文档树结构的推理型检索
人工智能·算法·架构