首页 > 其他 > 详细

数据结构-查找

时间:2019-11-01 21:16:34      阅读:97      评论:0      收藏:0      [点我收藏+]

一、二分查找

必须为有序数组

1.1递归实现

static int recursive(int[] arr,int low,int high,int target){
         if(target < arr[low] || target >arr[high] || low> high){
             return -1;
         }
         int middle = (low + high)/2;
         if(arr[middle] <target){
             return recursive(arr, middle+1, high, target);
         }else if(arr[middle]>target){
             return recursive(arr,0,middle-1, target);
         }
         else{
             return middle;
         }
     }

  1.2 循环实现

public static void main(String[] args) {
        Arrays.sort(array);
        int num = 1;
        int end = array.length-1,begin=0;
        while(array[(begin + end)/2] != num){
            if(num < array[(begin + end)/2]){
                end = (begin + end)/2;
            }
            else{
                begin=(begin + end)/2;
            }
        }
        System.out.println((begin + end)/2);
    }

  

数据结构-查找

原文:https://www.cnblogs.com/mushuise/p/11779087.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!