二分法查找(C语言)

二分法是一种高效的查找方法,其适用于已经排好序的数组

基本思路

从数组最中间的数开始查找判断,若不是需要查找的数字,则比较大小,之后则在从中间分开的两边中的一边从最中间开始查找判断,以此类推

算法描述

这里以升序数组为例,降序数组类似

  1. 记录数组最中间数的下标,将其中的数与要查找的数进行比较
  2. 若相等,停止查找,若大于要查找的数,则将数组下标上限换为较大半区的最小下标;若小于要查找的数,则将数组下标的下限换为较小半区的最大下标
  3. 重复第一步,直到数组下标不能调换,若查找到则停止查找,若未找到,则返回不存在的结果

代码实现

这里以升序数组为例,降序数组类似

# include<stdio.h>
int f(int, int [], int);
int main()
{
    int n;
    int arr[10]={1,2,3,4,5,6,7,8,9,10};
    scanf("%d", &n);//输入要查找的数
    int m=f(n, arr, 10-1);
    if(f(n, arr, 10-1)!=-1)
    printf("该数所在下标为:%d\n", m);
    else
    printf("该数不存在\n");
}
int f(int n, int a[], int h)
{
    int i, l, mid;
    l = 0;
    while(l<=h)//注意有等号,因为可能最后一次查找就只剩一个数,则这时上下限下标相等
    {
        mid=(l+h)/2;//计算中间下标
        if(a[mid]==n)//判断是否为目标数
        return mid;
        else if(a[mid]<n)
        l=mid+1;//如果中间数小于目标数,则将数组下限改为较大半区的下限
        else
        h=mid-1;//如果中间数大于目标数,则将数组上限改为较小半区的上限
    }
    return -1;//返回-1表示目标数不存在
}

原文地址:https://www.cnblogs.com/Xloading/p/12004049.html

时间: 2024-07-30 11:34:52

二分法查找(C语言)的相关文章

#C语言#二分法查找有序数组

C语言的二分法,想必很多朋友都在初学时是一个难啃的骨头,因为这是必须掌握的最基础的一种算法.在这里我分享一下这个简单的#二分法#查找有序数组 #include<stdio.h> int binary_search(int arr[],int key, int left, int right) { while (left <= right) { int mid = left + (right - left) / 2; if (a[mid]<key) { left = mid + 1;

JavaSE语言基础之数组二分法查找

一.概念: 算法:当数据量很大适宜采用该方法.采用二分法查找时,数据需是排好序的. 基本思想:假设数据是按升序排序的,对于给定值key,从序列的中间位置k开始比较, 如果当前位置arr[k]值等于key,则查找成功: 若key小于当前位置值arr[k],则在数列的前半段中查找,arr[low,mid-1]: 若key大于当前位置值arr[k],则在数列的后半段中继续查找arr[mid+1,high], 直到找到为止,时间复杂度:O(log(n)).(摘自百度百科) 二.代码 int[] arr

java的二分法查找数据

Java二分法查找的源代码:    二分查找是一种高效率线性表的查找算法.在查找时必须将线性表中的关键词排好序.基本思路是:先断定线性表的中心方位 mid=(first+last)/2:对比所要查找的关键词 key与中心方位的关键词的巨细,假如比key和mid.key持平则回来: key比mid.key大(假定为升序)这所要查找的关键词在mid和last之间:否则在first与mid之间.持续按照上面办法查找中心元素,直到找到为止.    详细完成如下package com.cgogo; /**

数组排序 和 二分法查找

二分法查找 当数据量很大适宜采用该方法.采用二分法查找时,数据需是有序不重复的. 基本思想:假设数据是按升序排序的,对于给定值 x,从序列的中间位置开始比较,如果当前位置值等于 x,则查找成功:若 x 小于当前位置值,则在数列的前半段中查找:若 x 大于当前位置值则在数列的后半段中继续查找,直到找到为止. 假设有一个数组 {5,4,2, 67, 77, 89, 90,4,9,1,12, 23, 34, 45, 56 },现要求采用二分法找出指定的数值并将其在数组的索引返回,如果没有找到则返回 -

JavaScript用二分法查找数据等

//二分法查数据 var arr=[41,43,45,53,44,95,23]; var b=44; var min=0; var max=arr.length; for(var i=1;i<arr.length;i++){ //外层循环控制排序的次数 for(var j=0;j<arr.length-i;j++){//内层循环控制循环的个数 if(arr[j]<arr[j+1]){ z=arr[j]; arr[j]=arr[j+1]; arr[j+1]=z; } } } // aler

python 实现二分法查找

二分查找图 二叉树: 代码 #!/usr/bin/python #-*-coding:utf-8-*- #---------------------------------------------------------------------------------------- # to_do : binary find # authors: zuoxingyu # time : 2014-06-07 #--------------------------------------------

python的算法:二分法查找(1)

1.什么是二分法查找: 1.从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束: 2.如果某一特定元素大于或者小于中间元素,则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较. 3.如果在某一步骤数组为空,则代表找不到. 每次都是i减半查找,其时间消耗为O(logn) 最简单的一个循环算法就是: def binary_search_loop(lst,value): low,high=0,len(value)-1 while low<=high: mid=

在数组中使用二分法查找

package com.db2; import java.util.Arrays; /** * 二分法查找 * * @author denny 使用二分法查找的前提数组已经排过序 * */ public class Demo4 { public static void main(String[] args) { int[] arr = { 3, 1, 8, 2, 9, 100, 33, 22, 11, 18, 14, 17, 15, 3 }; // 使用Arrays.sort()排序 Array

Java二分法查找实现

public class Dichotomy {        //定义查找次数    static int count = 0;        public static void main(String[] args) {                //定义数组        int [] array = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10};                //二分法查找        int result = searchRecursive

用二分法查找的套路(一)

需要注意的是: 1.二分法查找是在有序的基础上 2.确定判断是否找到的条件,确定判断函数 3.边界条件控制 1)闭区间[a,b] 2)半开半闭区间[a,b) 例题: 1.首个失败的产品. 这是一个闭区间的例子. 假设有一系列产品[1,2,3,4,5,6,7...],现在发现最新的产品是损坏的,你需要找出第一个失败了的产品,也就是出问题的那个产品.是否出问题通过函数isBadVersion(version)来判断. 分析: 1 int left =1; 2 int right =n;//n是数组长