zoukankan      html  css  js  c++  java
  • 来自AJPFX的二分法查找

    package com.heima.array;

    public class Demo2_Array {

            /**
             * * A:案例演示
                            * 数组高级二分查找代码
                    * B:注意事项
                            * 如果数组无序,就不能使用二分查找。
                                    * 因为如果你排序了,但是你排序的时候已经改变了我最原始的元素索引。

             */
            public static void main(String[] args) {
                    int[] arr = {11,22,33,44,55,66,77};
                    System.out.println(getIndex(arr, 22));
                    System.out.println(getIndex(arr, 66));
                    System.out.println(getIndex(arr, 88));
            }
            
            /*
             * 二分查找
             * 1,返回值类型,int
             * 2,参数列表int[] arr,int value
             */
            
            public static int getIndex(int[] arr, int value) {
                    int min = 0;
                    int max = arr.length - 1;
                    int mid = (min + max) / 2;
                    
                    while(arr[mid] != value) {                                        //当中间值不等于要找的值,就开始循环查找
                            if(arr[mid] < value) {                                        //当中间值小于了要找的值
                                    min = mid + 1;                                                //最小的索引改变
                            }else if (arr[mid] > value){                        //当中间值大于了要找的值
                                    max = mid - 1;                                                //最大的索引改变
                            }
                            
                            mid = (min + max) / 2;                                        //无论最大还是最小改变,中间索引都会随之改变
                            
                            if(min > max) {                                                        //如果最小索引大于了最大索引,就没有查找的可能性了
                                    return -1;                                                        //返回-1
                            }
                    }
                    return mid;
            }
    }

  • 相关阅读:
    leetcode 293.Flip Game(lintcode 914) 、294.Flip Game II(lintcode 913)
    Android开发 Fragment中调用startActivityForResult返回错误的requestCode
    AndroidStudio 编译异常java.lang.OutOfMemoryError: GC overhead limit exceeded
    Android 控制ScrollView滚动到底部
    安卓Textview的getLineCount返回0
    指定经纬度与数据库多条经纬度进行距离计算
    GPUImage 内置滤镜解析
    ViewPager中使用PhotoView时出现pointerIndex out of range异常
    “You must not call setTag() on a view Glide is targeting” 解决
    android studio出现Error:compileSdkVersion android-x requires compiling with JDK 7问题
  • 原文地址:https://www.cnblogs.com/AJPFX/p/10827579.html
Copyright © 2011-2022 走看看