Java学习笔记_Day15

二分查找

前提条件:数组中的数据必须是有序的

核心逻辑:每次排除一半的查找范围

java 复制代码
public static int binarySearch(int[] arr,int number){
        int min=0;
        int max=arr.length-1;
        while(true){
            if(min>max){
                return -1;
            }
            int mid=(min+max)/2;
            if(arr[mid]>number){
                max=mid-1;
            }
            else if(arr[mid]<number){
                min=mid+1;
            }
            else{
                return mid;
            }

}

冒泡排序

冒泡排序:相邻的数据两两比较,小的放前面,大的放后面

java 复制代码
public static void BubbleSort(int[] arr){
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;
                }
            }
        }

}

外循环:表示要执行多少轮,n个数据,执行n-1轮

内循环:每一轮中找到最大值,-1防止索引越界

选择排序

选择排序:从0索引开始,拿着每一个索引上的元素和后面的元素依次比较,小的放前面。

java 复制代码
public static void SelectSort(int[] arr) {
        for (int i = 0; i < arr.length-1; i++) {
            for (int j = i+1; j < arr.length; j++) {
                if(arr[i] > arr[j]) {
                    int temp = arr[i];
                    arr[i] = arr[j];
                    arr[j] = temp;
                }
            }
        }
    }

插入排序

插入排序:将0索引的元素看做是有序的,把N+1索引的元素到最后一个当成是无序的。

遍历无序的数据,将遍历的元素插入有序序列适当的位置

java 复制代码
public static void insertSort(int[] arr) {
        for (int i = 1; i < arr.length; i++) {
            for (int j = i-1; j >=0&&arr[j]> arr[j+1]; j--) {
               
                    int temp = arr[j];
                    arr[j] = arr[j+1];
                    arr[j+1] = temp;
                
            }

        }
    }
相关推荐
做个文艺程序员1 天前
流式输出(SSE)在 Spring Boot 中的实现【OpenClAW + Spring Boot 系列 第3篇】
java·spring boot·后端
逻辑驱动的ken1 天前
Java高频面试考点场景题09
java·开发语言·数据库·算法·oracle·哈希算法·散列表
小手cool1 天前
如何在Java中根据另一个配对集合对一个集合进行排序
java·开发语言
云烟成雨TD1 天前
Spring AI Alibaba 1.x 系列【28】Nacos Skill 管理中心功能说明
java·人工智能·spring
升鲜宝供应链及收银系统源代码服务1 天前
OMS 订单模块重构正式文档(一)---升鲜宝生鲜配送供应链管理系统
java·开发语言·重构·生鲜配送源代码·生鲜供应链源代码
Han.miracle1 天前
Redis 全套笔记:基础 API + 三大架构 + 缓存三大问题
java·windows·redis
zzb15801 天前
Fragment 生命周期深度图解:从 onAttach 到 onDetach 完整流程(面试必备)
android·java·面试·安卓
银色火焰战车1 天前
浅析golang中的垃圾回收机制(GC)
java·jvm·golang
三品吉他手会点灯1 天前
C语言学习笔记 - 1.C概述 - 本讲内容概述
c语言·笔记·学习
zhangjw341 天前
第4篇:Java数组与字符串:从基础用法到面试高频考点
java·java基础知识