冒泡与二分法的爱恨纠葛

冒泡排序与二分法查找


前言

冒泡排序,编程中,基础的基础,重中之重!什么是冒泡排序,怎么用,什么时候用?

二分法?听过,编程里咋写?咋用?


一、冒泡排序?二分法查找?

简单介绍

冒泡排序?使用两个for循环嵌套给数组进行排序

二分法查找?在有序的数组中找到你所要查找的元素,返回下标

二、冒泡排序的原理及使用

1.原理

众所周知,水泡是有浮力的,水泡越大浮力越大,离水面就越近,所以我们把数组看成一个水瓶,里面的元素是一个个水泡,现在的水泡是大小不一的排列着,采用冒泡排序后,可以将水泡排列成大小规律的顺序。

2.手写冒泡排序思路及实现

我们将数组中的每一个元素拿出来与其他元素进行比较,找到它在这个数组中的位置

java 复制代码
public class BubbleSort {
    public static void main(String[] args) {
        int[] arr = new int[]{43,32,76,-98,0,64,33,-21,32,99};
        //冒泡排序
        for(int i = 0;i < arr.length - 1;i++){
            for(int j = 0;j < arr.length - 1 - i;j++){
                if(arr[j] > arr[j + 1]){
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
    }
}

代码讲解

因为思路是要每一个元素都拿出来比较,所以将外层循环的操作看成抓取数组元素的操作,所以外层的循环条件就是从0开始,一直到数组的长度-1,相当于遍历数组,但是为什么i 不是小于等于,还要加-1,一会讲内层循环的操作看成将该元素与该元素后面的元素作比较,所以从 0 开始,重复数组元素个数 - i 遍结束。这样既提高效率,又能一个不落的全部比较一边,接下来就是一个逻辑判断,如果后面位置的元素比当前位置的元素大,那就调换位置(排列的顺序自己去调整,可以最小的在前面,也可以最大的在前面),这里注意到我用了 j 和 j + 1来表示两个位置的元素,所以我们在最开始设置循环条件的时候要在数组个数的基础上再-1,要不然会报错,超出数组长度。

效果演示/运行结果

这样现在我们的数组中就是按照顺序大小排列好的有序数组了。


三、二分法查找的原理及使用

1.原理

二分法查找,顾名思义,和数学中的二分法很像,没错,使用起来也很像,在数学中,需要使用在单调性统一的函数中,而在我们计算机里,需要使用在有序的数组里,其实道理是一样的,都是使用在数值逐渐增大或减小的目标中,这时候我们的数组如果是无序的,我们就需要用到上面介绍到的冒泡排序将数组变得有顺序。

2.二分法查找思路及实现

思路,传入一个目标值,在数组中获取中间值下标,将目标值与中间值作比较,如果相等,返回目标元素下标,如果不相等,重新赋一个中间值,重复以上操作,知道找到该元素为止。

java 复制代码
//二分法查找
        int dest = 64;                  //目标元素
        int head = 0;                   //数组的首位元素下标,用于计算中间值下标
        int end = arr.length - 1;       //数组的末尾元素下标,用于计算中间值下标
        boolean isFlag = true;          //判断找没找到的标志

        //开始查找操作
        while (head <= end){
            int mid = (head + end) / 2;
            if (dest == arr[mid]){
                isFlag = false;
                System.out.println("找到" + dest +"了!该元素在数组中的位置是:" + mid);
                break;
            }else if (arr[mid] > dest){
                end = mid - 1;
            }else{
                head = mid + 1;
            }
        }

        if (isFlag){
            System.out.println("没找到!!!");
        }

这里就是二分法查找的具体实现代码,如果查找的需求多,可以对其修改,将其封装成方法,根据具体需求具体改动,参数列表中放你需要查找的元素。

运行结果

总结

以上就是冒泡排序与二分法查找的详解,大家在开发实战中要灵活运用,如果这篇文章解决了你的问题,点个关注吧,持续更新中...

相关推荐
xlsw_1 小时前
java全栈day20--Web后端实战(Mybatis基础2)
java·开发语言·mybatis
神仙别闹2 小时前
基于java的改良版超级玛丽小游戏
java
黄油饼卷咖喱鸡就味增汤拌孜然羊肉炒饭2 小时前
SpringBoot如何实现缓存预热?
java·spring boot·spring·缓存·程序员
XH华2 小时前
初识C语言之二维数组(下)
c语言·算法
暮湫2 小时前
泛型(2)
java
超爱吃士力架2 小时前
邀请逻辑
java·linux·后端
南宫生2 小时前
力扣-图论-17【算法学习day.67】
java·学习·算法·leetcode·图论
转码的小石3 小时前
12/21java基础
java
不想当程序猿_3 小时前
【蓝桥杯每日一题】求和——前缀和
算法·前缀和·蓝桥杯
李小白663 小时前
Spring MVC(上)
java·spring·mvc