循环有序数组,查找值

2020-12-13 03:26

阅读:475

标签:第一个   rgs   ret   范围   通过   sort   main   length   ring   

一、从一个循环有序数组总查找给定值

  1、思路:先通过中间值和最后一个或者第一个元素比较,找出局部有序范围,再通过二分查找局部有序段

  

private static int sortArrFindOne(int arr[], int low, int high, int target) {
        int mid = (high - low) / 2 + low;
        if (arr[mid] == target) return mid;
        if (arr[mid] 

  2、找局部有序(二分递归查找)

  

//局部有序
    private static int find(int arr[], int low, int high, int target) {
        int mid = (high - low) / 2  + low;
        if (arr[mid] == target) return mid;
        if (arr[mid] 

  3、测试

public static void main(String[] args) {
        int arr[] = {6, 7, 8, 9, 1, 2, 3, 4, 5};
        System.out.println(sortArrFindOne(arr, 0, arr.length - 1, 8));
        System.out.println(sortArrFindOne(arr, 0, arr.length - 1, 1));
        System.out.println(sortArrFindOne(arr, 0, arr.length - 1, 5));
        System.out.println(sortArrFindOne(arr, 0, arr.length - 1, 6));
    }

  

循环有序数组,查找值

标签:第一个   rgs   ret   范围   通过   sort   main   length   ring   

原文地址:https://www.cnblogs.com/junxing/p/11074837.html


评论


亲,登录后才可以留言!