算法学习——二分查找(折半查找)

算法学习——二分查找

注意点

1. 二分查找的前提是有序的数组
2. 建议使用[start,end)的区间寻找,符合规范
3. 使用的是递归法

递归的人口

private static int find(int[] temp, int x) {
        //如果要查找的数x比数组的最后一个数要大,则找不到数值,返回-1
        if (x > temp[temp.length - 1]) {
            return -1;
        }
        return find(temp, 0, temp.length, x);//进入递归
}

递归的出口

private static int find(int[] temp, int start, int end, int x) {
        if (end - start == 1) {
            return -1;//出口
        }
        int mid = (start + end) / 2;
        if (x < temp[mid]) {
            return find(temp, start, mid, x);
        } else {
            if (x == temp[mid]) {
                return mid;//出口
            }
            return find(temp, mid, end, x);
        }
}

按照过程跑一遍就能够对二分查找有个深刻的理解,我觉得书上的有个while循环,要想半天才能想通

二分查找,返回数组中的查找到该数的下标值

public static void main(String[] args) {
        int[] data = {5, 6, 9, 15, 19, 53, 56};
        System.out.println(find(data,15));
    }

    private static int find(int[] temp, int x) {
        if (x > temp[temp.length - 1]) {
            return -1;
        }
        return find(temp, 0, temp.length, x);
    }

    private static int find(int[] temp, int start, int end, int x) {
        if (end - start == 1) {
            return -1;
        }
        int mid = (start + end) / 2;
        if (x < temp[mid]) {
            return find(temp, start, mid, x);
        } else {
            if (x == temp[mid]) {
                return mid;
            }
            return find(temp, mid, end, x);
        }
    }

二分查找,比要找的数大一点的数的下标(修改一下出口)

public static void main(String[] args) {
        int[] data = {5, 6, 9,9, 15, 19, 53, 56};
        System.out.println(find(data,14));
    }

    private static int find(int[] temp, int x) {
        if (x > temp[temp.length - 1]) {
            return -1;
        }
        return find(temp, 0, temp.length, x);
    }

    private static int find(int[] temp, int start, int end, int x) {
        if (end - start == 1) {
            return end;//后一个肯定比前一个大,返回后一个,start已经比较过了,temp[start]比x要小
        }
        int mid = (start + end) / 2;
        if (x < temp[mid]) {
            return find(temp, start, mid, x);
        } else {
            if (x == temp[mid]) {
                return mid+1;//找到了当前的数,之后的那个数肯定比当前的数大点
            }
            return find(temp, mid, end, x);
        }
    }

原文地址:https://www.cnblogs.com/kexing/p/10498060.html

时间: 2024-11-29 06:55:38

算法学习——二分查找(折半查找)的相关文章

二分查找/折半查找算法

二分查找又称折半查找,优点是比较次数少,查找速度快,平均性能好:其缺点是要求待查表为有序表,且插入删除困难.因此,折半查找方法适用于不经常变动而查找频繁的有序列表.首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功:否则利用中间位置记录将表分成前.后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表.重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功. class Pr

(java)有序表查找——折半查找,插值查找,斐波那契查找

有序表查找 /* 主函数 */ public class OrderTableSearch { public static void main(String[] args) { int [] a= {0,1,16,24,35,47,59,62,73,88,99}; System.out.println(FibonacciSearch(a, 10, 88)); System.out.println(InsertKeySearch(a, 10, 88)); System.out.println(Bi

顺序查找,折半查找,二叉排序树的建立,哈希表的建立

以下四个验证性实验都做. (1)顺序查找验证 (2)折半查找验证 (3)二叉排序树的建立 (4)哈希表的建立 #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> #include<string.h> #include<algorithm> using namespace std; class dijiuzhang { public: int a[1

java 二分查找 - 折半查找算法

二分查找: 这个算法是比较简单的,容易理解的.这个算法是对有序的数组进行查找,所以想要使用这个算法那么 首先先要对数组进行排序. 其实有三个指针,开始指针,末尾指针,中间指针,来开始.折半查找. 步骤如下: 1.确定三个指针,start,end,middleIndex. 2.判断start<=end,如果满足,就执行这个方法,不满足,就返回,找不到. 3.在2的前提下,我们对其折半查找,middleIndex = start+end >> 1,取中间值. 4.判断中间位置的值和目标值是否

Java 实现二分查找\折半查找

二分查找又称折半查找,优点是比较次数少,查找速度快:其缺点是要求待查表为有序表,且插入删除困难.因此,折半查找方法适用于不经常变动而查找频繁的有序列表. 该算法要求: 1.  必须采用顺序存储结构. 2.  必须按关键字大小有序排列. 该算法时间复杂度最坏为:O(logn) 注意点有mid.low.high 其Java实现代码如下(该代码有缺陷,只是基本实现,有待完善): public class BinarySearch { /** * @param args */ public static

二分查找/折半查找

二分查找又叫折半查找. 前提:数组是有序的. 思想:1.每次都拿中间的数的key进行比较,如果相等,找到: 2.如果key > 中间数,说明key在中间数的右边,接着拿右边的中间数和key比较: 3.如果key < 中间数,说明key在中间数的左边,接着拿左边的中间数和key比较: 4.循环上述过程: 啥也不说了,上代码: 1 #include <stdio.h> 2 3 int main(int argc, const char * argv[]) { 4 5 // 定义数组 6

二分法查找(折半查找)

顺序查找并没有对表中的关键字域的顺序做出任何假设,与顺序查找不同,在折半查找中,表中的记录是按关键字域有序排列的,其比较会出现下面三种结果: searchumn< list[middle].key,此时,无需考虑位于list[middle]和list[n-1]之间的记录,而继续查找位于list[0]和list[middle-1]间的记录. searchnum=list[middle].key,此时,查找成功,结束查找. searchnum>list[middle].key,此时,无需考虑位于l

算法学习----二分查找算法

关于二分查找,一直稀里糊涂,终于在看了一些资料后,总结出一个比较实用的记法. http://www.cnblogs.com/huang1990/archive/2013/04/02/2995284.html http://my.oschina.net/wangliannet/blog/140480 总的原则为,区间规则形式一样,区间之间不重复,不漏值. 令待查数组为source[],数组维数为size,要查的的数位key. 区间划分的原理:1.左闭右闭的划分法[ ) head=0,tail=si

二分查找/折半查找(C++实现)

要求:给定已按升序排好序的n个元素a[0:n-1],现要在这n个元素中找出一特定元素x. 分析: 该问题的规模缩小到一定的程度就可以容易地解决: 如果n=1即只有一个元素,则只要比较这个元素和x就可以确定x是否在表中.因此这个问题满足分治法的第一个适用条件 该问题可以分解为若干个规模较小的相同问题; 分解出的子问题的解可以合并为原问题的解: 分解出的各个子问题是相互独立的. 比较x和a的中间元素a[mid], 若x=a[mid],则x在L中的位置就是mid: 如果x<a[mid],则x在a[mi