美文网首页
二分法查找

二分法查找

作者: syimo | 来源:发表于2016-11-13 00:23 被阅读0次

1,二分法查找,插入元素位置


/**
 * 二分法查找元素,没有则返回-1
 * 扩展,在数组中插入某个元素,插入的元素的下标位置即为left值
 * @author xhq
 *
 */
public class halfSearch {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int arr[] = { 2, 4, 6, 7, 8, 9, 11, 13};
        int index = halfSearch(arr, 6);
        int insert = halfSearchInsert(arr, 6);
        System.out.println(index);
        System.out.println(insert);
    }

    public static int halfSearch(int[] arr, int key) {
        int left = 0;
        int right = arr.length - 1;
        while (left <= right) {
            int mid = (left + right) / 2;
            if (arr[mid] == key)
                return mid;
            if (arr[mid] > key)
                right = mid - 1;
            else
                left = mid + 1;
        }
        return -1;
    }
    public static int halfSearchInsert(int[] arr, int key) {
        int left = 0;
        int right = arr.length - 1;
        while (left <= right) {
            int mid = (left + right) / 2;
            if (arr[mid] == key)
                return mid;
            if (arr[mid] > key)
                right = mid - 1;
            else
                left = mid + 1;
        }
        return left;
    }
}

2,数组旋转,求最小值问题



public class N08 {
    /**
     * 题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个排好序的数组的一个旋转,输出旋转数组的最小元素。
     * 例如数组{3,4, 5, 1, 2}为{1, 2, 3, 4, 5}的一个旋转,该数组的最小值为1。
     * 1,假设数组第0个元素移到后面?降序或者升序?
     * 2,对于1 0 1 1 1 1 1 1  1...的处理?
     * 3,非旋转数组怎么判断?
     * 4,以下算法只适用于一串升序数组的旋转。
     * 参考:http://zhedahht.blog.163.com/blog/static/25411174200952765120546/
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int[] arr = { 3, 4, 5, 1, 2 };
        int min = searchMin(arr);
        System.out.println(min);

    }

    private static int searchMin(int[] array) {
        int left = 0;
        int right = array.length - 1;
        while (left <= right) {
            int mid = (left + right) / 2;
            if (right - left == 1)
                break;
            if (array[mid] >= array[left])
                left = mid;
            else {
                right = mid;
            }
        }
        return array[right];
    }

}

参考

旋转数组的最小元素

相关文章

  • 二分法查找

    二分法基本查找 二分法遍历查找

  • 二分法查找

    二分法查找的前提是数组必须排序!!!二分法查找的前提是数组必须排序!!!二分法查找的前提是数组必须排序!!!二分法...

  • 刷前端面经笔记(九)

    1.JavaScript实现二分法查找? 二分法查找,也称折半查找,是一种在有序数组中查找特定元素的搜索算法。查找...

  • 数据结构-递归

    二分法查找

  • 查找算法

    三种查找算法:顺序查找,二分法查找(折半查找),分块查找,散列表

  • 二分查找

    以二分法来提升查找效率 二分法查找到key的合适位置 put get delete 二分查找的查找操作为O(log...

  • 算法和排序

    1、线性查找 2、二分法查找 3、冒泡排序

  • 查找算法

    查找算法 顺序查找法 时间复杂度:O(n) 二分法查找 二分法查找适用于有顺序的序列 时间复杂度:O(n) 核心思...

  • 算法图解1-2/11

    原书作者 Aditya Bhargava 1 算法简介 1.1 二分法查找 二分法查找,正是猜数字游戏的玩法:A...

  • 前端面试之算法二分法

    使用二分法的前提是,目标数组的元素必须是有序排列的,所以二分法属于有序查找算法 二分法又称为“折半查找”,从数组的...

网友评论

      本文标题:二分法查找

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