首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言函数二分查找(折半查找)

C语言函数二分查找(折半查找) 参考视频讲解哔哩哔哩比特鹏哥的视频 ——链接 二分查找 #include //二分查找 //在一个有序数组中查找具体的某个数 //如果找到了返回...//查找了一次范围就缩小了一半,这样的速度是比较快的 //这就叫二分查找(折半查找) //那么怎么找到中间元素的下标呢 //原来的数组是1 2 3 4 5 6 7 8 9 10 //他们的下标是...else { printf("找到了,下标是:%d\n",ret); } return 0; } //运行发现找不到结果——代码出现了问题 //自己找问题的方法 //部分位置添加注释后 二分查找...#include int number_search(int arr[], int k) //实际上这地方传递过来的数组arr是首元素地址 //本质上这里的arr是个指针,因为指针才可以接收地址...//在这里要进行很多次 //每一次二分查找的第一步是找被查找范围的中间元素的下标 while (left <= right) { int mid = (right + left

88720

C语言二分查找算法

二分查找又称折半查找二分搜索、折半搜索等 是一种在静态查找表中查找特定元素的算法使用二分查找算法,必须保证查找表中存放的是有序序列(升序或者降序),换句话说,存储无序序列的静态查找表,除非先对数据进行排序...,否则不能使用二分查找算法 一....举个例子: 二分查法是根据[(left+right)/2]的比较来确定哪个是我们需要的数字,left(左)和right(右)不断的变化,而中间的范围值也在不断缩小(C语言正常情况下是没有四舍五入的)...二.以上是我们的二分查找算法的分析,下面看代码实现: (1)先要确定我们的变量值和要查的那个数值: #include int main() { int arr[10]...,判断这个数和目标的大小比较,最终快速的确定目标是否在我们的数组中 在这些的大前提下还有知道的就是二分查找法查的必须是有序数列,我们在查找时需要先进行排序,这些我也提前都准备好了: 我的文章中有关于冒泡排序的讲解

5910
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    轻松拿捏C语言——二分查找

    一、介绍 二分查找是一种在有序数组中查找某一特定元素的搜索算法。 举个生活中的例子,当我们要去图书馆借书时,知道了要找的图书编号,我们可以在一个大致范围的中间查找,然后在决定往前找还是往后找。...搜索过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜索过程结束; 如果某一特定元素大于或者小于中间元素,则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较。...} else { printf("元素 %d 不在数组中\n",key); } return 0; } 使用循环的方式来实现二分查找...无论使用哪种方式,都需要确保数组是有序的,因为二分查找的前提是有序数组。

    9910

    C语言二分查找与冒泡排序

    ✨作者:@平凡的人1 ✨专栏:《C语言从0到1》 ✨一句话:凡是过往,皆为序章 ✨说明: 过去无可挽回, 未来可以改变 ---- 二分查找 在有序数组中查找具体的某个数字n,...我们一般从中间元素开始找,查一次去掉一半数字,这种方法我们给它取名为折半查找即为二分查找,效率大大提高!怎么理解呢?...注意点:关键在于有序数组,也就是说,二分查找存在缺陷:不能在无序数组中使用,当然对于无序数组你也可以选择排一下序。...思路分析 二分查找的基本思想是将n个元素分成大致相等的两部分,取a[n/2](即中间元素)与x做比较,如果x=a[n/2],则找到x,算法中止;如果x<a[n/2],则只要在数组a的左半部分继续搜索x,...代码实现: 第一种形参是数组 第二种形式是指针

    1K30

    C语言C语言基础习题详解(牛客网)&&二分查找逻辑

    =*right; *right=tmp; left++; right--; } } 逆序整个字符串,调用这个函数,逆序单词同样可以调用这个函数 用while循环,当开始指针遇到空格或者...10的数组,我们给定他的下界left=0,上界right=numsLen-1,中间下标mid=(left+right)/2 ​ 二分查找: 判断目标值target是否等于num[mid]; 如果相等则返回...(price-min):maxProfit; } return maxProfit; } 7.二分查找逻辑 7.1 二分查找 二分查找是我们经常使用的一种算法,他的逻辑是 在升序或者降序且无重复元素的数组中...循环,当left<right的时候循环,直到找到目标值对应的下标,返回下标;或者没有目标值对应的下标,返回-1; 7.3 题目练习 我们找到一个题目来练习一下 7.3.1 题目描述 牛客网的题目链接: 二分查找...-I_牛客题霸_牛客网 (nowcoder.com) 7.3.2 代码示例 根据二分查找的逻辑,我们可以写下代码: int search(int* nums, int numsLen, int target

    11610

    C语言必刷题】3.二分查找

    前言 二分查找又称为折半查找,是分治算法基础上设计出来的查找算法。 二分查找算法仅适用于有序序列,它只能用升序序列或者降序序列中查找目标元素。...算法描述 二分查找的核心思想:不断地缩小搜索的区域,降低查找目标元素的难度。 前提:有已排序的数组arr。 定义左边界(Left),定义右边界(Right),确定搜索范围,循环执行二分查找....arr[Middle] == t 表示知道了,返回中间下标 arr[Middle] > t 中间值右侧的其他元素都大于t,不需要比较,中间下标左边去找,Middle - 1 设置右边界,重新查找。...arr[Middle] < t 中间值左侧的其他元素都小于t,不需要比较,中间下标右边去找,Middle + 1 设置左边界,重新查找。 当 Left > Right ,表示没有找到,循环结束。...算法实现 void binarysearch(int arr[], int Length, int t) // 数组、数组长度和要查找的数 { int find = -1;//标记 int Left

    12010

    C语言每日一题(6)二分查找

    思路分析 1.二分查找的基本思想 二分查找的基本思想是通过比较中间元素与目标元素的大小来不断缩小搜索范围,直到找到目标元素或确定目标元素不存在为止。其基本步骤如下: 1....重复步骤2和步骤3,在新的搜索范围内进行二分查找,直到找到目标元素或确定目标元素不存在为止。如果搜索范围为空,即开始索引大于结束索引,则目标元素不存在。...二分查找的关键在于每次通过比较中间元素来确定目标元素的可能位置,将搜索范围缩小一半,从而大大减少了搜索的次数,提高了查找效率。但前提是数组或列表必须是有序的。...target ) { if (numsLen <= 0)return -1; int low = 0, high = numsLen - 1; //初始化双指针...= nums[mid] && low <= high) { //若当前mid值不为查找值,更新查找区域。

    10010

    C语言】一维数组(含数组二分查找)

    这里的地址使用的是16进制表达,可以看出每一个元素的地址之间隔了4个字节,而刚好数组中存放的是整形元素,大小为4个字节,由此可以看出,数组在内存中的存储是连续的,是由低到高的,了解之后对我们以后学习指针帮助...left]; arr2[right] = arr1[right]; left++; right--; printf("%s\n", arr2); } return 0; } 练习2.二分查找...1.二分查找介绍:     在⼀个升序的数组中查找指定的数字n,很容易想到的⽅法就是遍历数组,但是这种⽅法效率⽐较低。    ...,也叫折半查找 2.要求:     创建一个数组arr,里面包含1,2,3,4,5,6,7,8,9,10 共十个元素,用户输入一个值,然后通过二分查找快速查询用户输入的值是否在数组中,如果在就输出找到了...,如果不在就输出找不到: 3.分析: (1)根据二分查找我们需要找到中间元素,就可以用最左下标和最右下标的中间值,也就是它们的平均数,上例子我们介绍了最左下标和最右下标如何求,这里不再赘述,主要看看如何求中间下标

    9210

    C语言指针(野指针)

    2:如何规避野指针 1.1:指针变量的初始化 2.2:指针越界访问 3.3:指针指向的空间如果我们还回去的话,就把指针指针置为NULL  4.4:指针使用之前检查有效性 1:什么是野指针?...指针越界也会导致野指针问题,这里解释下:就是当你指针指向的范围超过数组名范围时,那么那个指针就是野指针了。...2:如何规避野指针 1.1:指针变量的初始化 int a = 10; int* pa = &a; //指针变量的初始化 指针常见错误 引用未初始化的指针变量 试图引用未初始化的指针变量是初学者最容易犯的错误...3.3:指针指向的空间如果我们还回去的话,就把指针指针置为NULL NULL——空指针,用来初始化指针或者给指针赋值,可以转到定义看看 #define NULL    ((void *)0) 说的简单一点就是...空指针不应与未初始化的指针混淆:保证空指针与指向有效对象的任何指针进行比较。但是,根据语言和实现,未初始化的指针可能没有任何此类保证。它可能与其他有效指针相等; 或者它可能比较等于空指针

    2.6K20

    C语言指针

    二、指针的定义 三、指针的初始化 四、指针运算符 五、指针的用途举例 六、关于指针的疑问 指针C语言中非常重要的数据类型,如果你说C语言中除了指针,其他你都学得很好,那你干脆说没学过C语言。...1.我们已经知道,"直接引用"是直接通过变量名来读写变量 2.C语言中还有一种"间接引用"的方式(以变量a为例):首先将变量a的地址存放在另一个变量中,比如存放在变量b中,然后通过变量b来间接引用变量a...* 看下面的代码,利用指针p读取变量c的值 1 int i = 2; 2 char c = 1; 3 4 // 定义一个指向char类型的指针 5 char *p = &c; 6 7 // 取出 8...* 如果我改一下第5行的代码,用一个本应该指向int类型变量的指针p,指向char类型的变量c int *p = &c; 我们再来看一下输出: ? ,c的原值是1,现在取出来却是513,怎么回事呢?...这个要根据内存来分析 根据变量的定义顺序,这些变量在内存中大致如下图排布: 其中,指针变量p和int类型变量i各占2个字节,char类型的c占一个字节,p指向c,因此p值就是c的地址 ?

    3.3K60

    C - 指针C语言指针的总结

    C语言指针的总结 1. 变量 不同类型的变量在内存中占据不同的字节空间。 内存中存储数据的最小基本单位是字节,每一个字节都有一个内存地址,这个地址是一个十六进制的数。...什么是指针:变量的地址叫做指针指针就是地址,地址就是指针。 下面通过一张图可以更直观的理解内存中的地址 ? 内存中的地址演示图 2. 指针 指针C语言的灵魂。指针变量占据8个字节。...p操作的是p这个指针变量,可以取p得值,也可以为p赋值 指针变量的使用 可以使用指针间接的操作指针指向的变量。 *p 代表 p 指针指向的变量。...指针为什么要分类型? 多级指针 一个指针变量中存储的是一个一级指针的地址,那么它就是二级指针,一个指针变量中存储的是一个二级指针的地址,那么它就是三级指针。...二级指针:数据类型 ** 指针名 二级指针只能存储一级指针变量的地址。 多级指针在开发中很少用到,遇到多级指针耐心分析一定可以理清其中的关系。

    4.2K81

    C语言——指针

    目录 指针是什么? 指针变量 使用指针变量的例子 通过指针引用数组 &数组名vs数组名 野指针指针成因 如何避免野指针 指针运算 指针是什么?...指针c语言中的一个重要概念,也是C语言的一个重要的特色,正确而灵活地运用它,可以使程序简洁,紧凑,高效,每一个学习和使用c语言的人,都应当深入了解地学习和掌握指针,可以说,不掌握指针就是没有掌握C的精华也可以说...指针C语言的灵魂(doge) 由于通过地址能找到所需的变量单元,可以说,地址指向变量单元,打个比方,一个房间的门口挂了一个房间号2008,这个2008就是房间的地址,或者说,2008"指向"...下面来看一段代码: 这里我们可以发现p跟p+1相差1 这里c是多少呢 ?...16进制的C的10进制是12,所以q+1和q相差4  p是整型指针相当于sizeof(int)=4 q是字符型指针相当于sizeof(char)=1; 以上就是我归纳指针的一些小结 如果能帮助友友们 -

    2.3K20

    C语言: 指针

    目录 概念: 指针的类型 指针的解引用 野指针指针的成因 空指针 指针与数组 指针在数组中的使用: 二级指针 ---- 概念: 在计算机科学中,指针(Pointer)是编程语言中的一个对象,利用地址...指针的类型与指向的目标的类型一致,指针指向的是目标的地址。...野指针 概念: 野指针就是指针指向的位置是不可知的(随机的、不正确的、没有明确限制的)指针变量 在定义时如果未初始化,其值是随机的,指针变量的值是别的变量的地址,意味着指针指向了一 个地址是不确定的变量...1、指针初始化  2、小心越界访问 3、指针指向的空间释放 4、使用之前检查有效性 空指针 即是将指针置空 int* p = NULL; 指针与数组 #include <stdio.h...0; } 指针指向的是目标变量的地址,那么二级指针指向的就是指针的地址。

    2K70
    领券