美文网首页
二分查找算法的两种实现

二分查找算法的两种实现

作者: 昔日的帅哥 | 来源:发表于2019-07-30 18:50 被阅读0次
public class Search {

    /**
     * while循环实现
     */
    public static int binarySearch(int[] array, int target) {
        int low = 0;
        int high = array.length - 1;
        int mid;
        while (low <= high) {
            //防止int溢出
            mid = low + (high - low) / 2;
            if (array[mid] == target) {
                return mid;
            } else if (array[mid] > target) {
                high = mid - 1;
            } else {
                low = mid + 1;
            }
        }
        return -1;
    }

    /**
     * 递归实现
     */
    public static int recursionBinarySearch(int[] array, int target, int low, int high) {

        if (target < array[low] || target > array[high] || low > high) {
            return -1;
        }
        int mid = (low + high) / 2;

        if (array[mid] > target) {
            return recursionBinarySearch(array, target, low, mid - 1);
        } else if (array[mid] < target) {
            return recursionBinarySearch(array, target, mid + 1, high);
        } else {
            return mid;
        }
    }
    
    /**
     * 测试
     */
    public static void main(String[] args) {
        int[] array = {1, 3, 5, 7, 9, 11};
        int target = 9;
//        int position = binarySearch(arr, key);
        int position = recursionBinarySearch(array, target, 0, array.length - 1);

        if (position == -1) {
            System.out.println("查找的是" + target + ",序列中没有该数!");
        } else {
            System.out.println("查找的是" + target + ",找到位置为:" + position);
        }
    }
}

相关文章

  • 二分查找算法--Python语言描述

    当列表的数据是有序的情况下, 使用二分查找算法是非常高效的, 以下使用两种方式实现了二分查找。 二分查找的一般算法...

  • 分治算法(swift二分法排序递归实现)

    二分查找 1、二分查找(Binary Search) 2、二分查找的基本思想 swift算法实现

  • 算法之二分查找

    二分查找 二分查找是著名、高效并有应用广泛的查找算法。 二分常规实现 1.循环实现 下面我用python语言实现循...

  • 算法之二分查找

    排序算法 二分查找 用于有序元素列表的查找性能: Python实现: C#实现

  • 刷题笔记

    算法思想 一、二分查找 1. 算法思想 算法详解 算法细节 一定要看二分查找细节.md 实现时需要注意以下细节: ...

  • 数据结构与算法之美笔记——二分查找(下)

    摘要: 基础的二分查找算法无论是概念还是实现都比较简单(关于 二分查找基础实现文章 可点击此处查看),但二分查找存...

  • 算法-二分搜索算法

    算法:二分搜索算法(折半查找算法)时间复杂度: 二分搜索算法概述 二分搜索算法伪代码 二分搜索算法实现 二分搜索算...

  • 查找算法

    查找算法 1顺序查找 2二分查找 2.1二分查找思路分析 2.2代码实现 3插值查找 3.1插值查找原理介绍: ​...

  • 数据结构和算法--二分查找

    二分查找 二分查找的思想 二分查找(Binary Search)算法,也叫折半查找算法。 二分查找针对的是一个有序...

  • 剑指offer学习笔记:2.4 算法和数据操作

    2.4 算法和数据操作 重点关注二分查找,归并排序和快速排序。很多算法都有递归和循环两种不同实现方法。通常基于递归...

网友评论

      本文标题:二分查找算法的两种实现

      本文链接:https://www.haomeiwen.com/subject/hgkorctx.html