zoukankan      html  css  js  c++  java
  • 循环有序数组,查找值

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

      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] < arr[high]) {
                if (arr[mid] < target && target <= arr[high]) {
                    return find(arr, mid, high, target);
                } else {
                    return sortArrFindOne(arr, low, mid, target);
                }
            } else {
                if (arr[low] <= target && target < arr[mid]) {
                    return find(arr, low, mid, target);
                } else {
                    return sortArrFindOne(arr, mid, high, target);
                }
            }
        }
    

      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] < target) {
                return find(arr, mid + 1, high, target);
            } else {
                return find(arr, low, mid - 1, target);
            }
        }
    

      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));
        }
    

      

  • 相关阅读:
    第四周查漏补缺20165307
    第四周作业 20165307
    第三周作业 20165307
    20165307 第一次测试总结
    20165307 预备作业3 Linux安装及学习
    20165307 学习基础和C语言基础调查
    20165307 我期望的师生关系
    第十周课下补做
    20165336 2016-2017-2 《Java程序设计》第9周学习总结
    20165336 实验三 敏捷开发与XP实践
  • 原文地址:https://www.cnblogs.com/junxing/p/11074837.html
Copyright © 2011-2022 走看看