java 常用二分

简介: 二分法查找(折半查找) java版本

二分法查找(折半查找):


第一:二分法查找建立在排序的基础之上。
第二:二分法查找效率要高于“一个挨着一个”的这种查找方式。
第三:二分法查找原理?
    10(0下标) 23 56 89 100 111 222 235 500 600(下标9) arr数组
    
    目标:找出600的下标
        (0 + 9) / 2 --> 4(中间元素的下标)
    
    arr[4]这个元素就是中间元素:arr[4]是 100
    100 < 600
    说明被查找的元素在100的右边。
    那么此时开始下标变成:4 + 1

        (5 + 9) / 2 --> 7(中间元素的下标)
        arr[7] 对应的是:235
        235 < 600
        说明被查找的元素在235的右边。
    
    开始下标又进行了转变:7 + 1
        (8 + 9) / 2 --> 8
        arr[8] --> 500
        500 < 600
        开始元素的下标又发生了变化:8 + 1
        (9 + 9) / 2 --> 9
        arr[9]是600,正好和600相等,此时找到了。

二分法查找的终止条件:一直折半,直到中间的那个元素恰好是被查找的元素。

二分法查找算法是基于排序的基础之上。(没有排序的数据是无法查找的。)


//测试代码
public class ArrayUtil {

public static void main(String[] args) {
    int[] arr = {100,200,300,400,500,600,1000,2000,9999};

// 找出arr这个数组中200所在的下标
// 调用方法

    int index = binarySearch(arr,200);
    System.out.println(index == -1 ? "该元素不存在" : "该元素的下标:" + index);
}

/**
 * 从数组中查找目标元素的下标
 * @param arr 被查找的数组(必须是已经排序的)
 * @param dest 目标元素
 * @return -1表示该元素不存在,其他表示该元素的下标
 */
private static int binarySearch(int[] arr, int dest) {

// 开始下标

    int begin = 0;

// 结束下表

    int end = arr.length - 1;

// 开始元素的下标只要在结束元素的下标的左边,就有机会继续循环

    while(begin <= end) {

// 中间元素的下标

        int mid = (begin + end) / 2;
        if (arr[mid] == dest) {
            return mid;
        } else if (arr[mid] < dest) {

// 目标在中间的右边
// 开始元素的下标需要发生变化(开始元素的下标需要重新赋值)

            begin = mid + 1; //一直增
        } else {

// arr[mid] > dest
// 目标在中间元素的左边
// 修改结束元素的下标

            end = mid - 1; //一直减
        }
    }
    return -1;
}

}

目录
相关文章
|
21天前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
59 0
|
1月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
94 16
|
2月前
|
缓存 并行计算 安全
关于Java多线程详解
本文深入讲解Java多线程编程,涵盖基础概念、线程创建与管理、同步机制、并发工具类、线程池、线程安全集合、实战案例及常见问题解决方案,助你掌握高性能并发编程技巧,应对多线程开发中的挑战。
|
2月前
|
数据采集 存储 前端开发
Java爬虫性能优化:多线程抓取JSP动态数据实践
Java爬虫性能优化:多线程抓取JSP动态数据实践
|
3月前
|
Java API 调度
从阻塞到畅通:Java虚拟线程开启并发新纪元
从阻塞到畅通:Java虚拟线程开启并发新纪元
309 83
|
3月前
|
安全 算法 Java
Java 多线程:线程安全与同步控制的深度解析
本文介绍了 Java 多线程开发的关键技术,涵盖线程的创建与启动、线程安全问题及其解决方案,包括 synchronized 关键字、原子类和线程间通信机制。通过示例代码讲解了多线程编程中的常见问题与优化方法,帮助开发者提升程序性能与稳定性。
145 0
|
3月前
|
存储 Java 调度
Java虚拟线程:轻量级并发的革命性突破
Java虚拟线程:轻量级并发的革命性突破
263 83
|
4月前
|
移动开发 Java
说一说 Java 是如何实现线程间通信
我是小假 期待与你的下一次相遇 ~

热门文章

最新文章