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

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

C语言函数二分查找(折半查找) 参考视频讲解哔哩哔哩比特鹏哥的视频 ——链接 二分查找 #include //二分查找 //在一个有序数组中查找具体的某个数 //如果找到了返回...//查找了一次范围就缩小了一半,这样的速度是比较快的 //这就叫二分查找(折半查找) //那么怎么找到中间元素的下标呢 //原来的数组是1 2 3 4 5 6 7 8 9 10 //他们的下标是...//左右下标又可以求出一个平均值是7,又找到一个对应的元素是8 //所以这一组查找范围的中间元素是8 //用8再跟我要找的元素比一下,比我找的元素要大 //说明我要查找的元素在8的左边 //这时候要查找的范围被再次的缩小成了...//一直找到左右下标无法确定新的范围,他们之间没有元素可以被查找的时候,结束,说明没有找到 //如果在某一次查找的时候,找到了,下标相等了,说明找到了,把下标给过来 int number_search...//在这里要进行很多次 //每一次二分查找的第一步是找被查找范围的中间元素的下标 while (left <= right) { int mid = (right + left

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

C语言 | static静态变量

“要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一” ——包租婆 这道理放在C语言学习上也一并受用。...在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历的是日积月累的学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...例87:学习C语言static定义静态变量的用法。 解题思路:在C语言中,static 不仅可以用来修饰变量,还可以用来修饰函数,使用 static 修饰的变量,称为静态变量。...C语言源代码演示: #include//头文件 int main()//主函数 { void varfunc(); //函数声明 int i;//定义整型变量 for...读者需要注意的一点是:静态变量属于静态存储方式,属于静态存储方式的变量却不一定就是静态变量。

96732

C语言 | static静态变量

例87:学习C语言static定义静态变量的用法。  解题思路:在C语言中,static 不仅可以用来修饰变量,还可以用来修饰函数,使用 static 修饰的变量,称为静态变量。...静态变量的存储方式与全局变量一样,都是静态存储方式。...C语言源代码演示: #include//头文件  int main()//主函数  {   void varfunc(); //函数声明    int i;//定义整型变量    for...读者需要注意的一点是:静态变量属于静态存储方式,属于静态存储方式的变量却不一定就是静态变量。...以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~ C语言学习路线     C语言开发工具 更多案例可以go公众号:C语言入门到静通

1.4K52

DS静态查找之折半查找

题目描述 给出一个队列和要查找的数值,找出数值在队列中的位置,队列位置从1开始 要求使用折半查找算法 输入 第一行输入n,表示队列有n个数据 第二行输入n个数据,都是正整数,用空格隔开 第三行输入t...,表示有t个要查找的数值 第四行起,输入t个数值,输入t行 输出 每行输出一个要查找的数值在队列的位置,如果查找不成功,输出字符串error 输入样例1  8 11 22 33 44 55 66...77 88 3 22 88 99 输出样例1 2 8 error 思路分析 折半查找就是二分查找,,对于一个有序数列,通过三个位置的变换(low、mid、high),相当于部分顺序查找...,只不过每次把查找的范围缩小一半。...,如果比mid位置的小,那么说明数值有可能在low和mid之间,那么就让high=mid-1,mid=(low+high)/2,继续查找下去,直到mid位置上的就是要查找的数值,或者low>high,查找结束

14320

9.2 静态查找

4、对于查找算法来说,通常只需要一个或几个辅助空间。 5、为确定记录在查找表中的位置,需和给定值进行比较的关键字个数的期望值称为查找算法在查找成功时的平均查找长度。...6、顺序查找的缺点是平均查找长度较大,查找效率较低。然而,它有很大的优点是:算法简单且适应面广。 02有序表的查找 1、以有序表表示静态查找表时,Search函数可用折半查找来实现。...03 静态树表的查找 1、称PH值取最小的二叉树为静态最优查找树(Static Optimal Search Tree)。...04索引顺序表的查找  1、若以索引顺序表表示静态查找表,则Search函数可用分块查找来实现。 2、分块查找又称索引顺序查找,这是顺序查找的一种改进方法。...C语言 | 心形表白神器 更多案例可以go公众号:C语言入门到精通

6632120

9.2 静态查找

01 顺序表的查找 1、顺序查找(Sequential Search)的查找过程为:从表中最后一个记录开始,逐个进行记录的关键字和给定值的比较,若某个记录的关键字和给定值比较相等,则查找成功,找到所查记录...4、对于查找算法来说,通常只需要一个或几个辅助空间。 5、为确定记录在查找表中的位置,需和给定值进行比较的关键字个数的期望值称为查找算法在查找成功时的平均查找长度。...6、顺序查找的缺点是平均查找长度较大,查找效率较低。然而,它有很大的优点是:算法简单且适应面广。 02 有序表的查找 1、以有序表表示静态查找表时,Search函数可用折半查找来实现。...03 静态树表的查找 1、称PH值取最小的二叉树为静态最优查找树(Static Optimal Search Tree)。...04 索引顺序表的查找 1、若以索引顺序表表示静态查找表,则Search函数可用分块查找来实现。 2、分块查找又称索引顺序查找,这是顺序查找的一种改进方法。

4643129

c++ 静态函数_c语言if结构格式

大家好,又见面了,我是你们的朋友全栈君 1、对象与对象之间的成员变量是相互独立的.要想共用数据,则需要使用静态成员或静态方法 2、只要在类中声明静态成员变量,即使不定义对象,也可以为静态成员变量分配空间...,进而可以使用静态成员变量.....静态成员变量是在程序编译时分配空间,而在程序结束时释放空间. 4、初始化静态成员变量要在类的外面进行.初始化的格式如下:数据类型 类名::静态成员变量名 = 初值; 5、不能用参数初始化表,对静态成员变量进行初始化.... 6、即可以通过类名来对静态成员变量进行引用,也可以通过对象名来对静态成员变量进行引用. 7、普通成员函数和静态成员函数的区别是: 普通成员函数在参数传递时编译器会隐藏地传递一个this指针,通过this...指针来确定调用类产生的哪个对象; 但是静态成员函数没有this指针,不知道应该访问哪个对象中的数据;所以在程序中不可以用静态成员函数访问类中的普通变量.

74720

C语言---静态库VS动态库

C语言中,函数库文件分为两种类型,一种是静态库(库程序是直接注入目标程序的,不分彼此,库文件通常以.a结尾),另一种是动态库(库程序是在运行目标程序时(中)加载的,库文件通常以.so结尾),下面我们就探索一下这两种库文件的特点和使用方式吧...例如hello.c中的打印函数printf,这个函数不是凭空出现的,在链接的过程中就要连同对应库文件一起打包,最终可执行文件才能正常运行。 静态库VS动态库 静态库和动态库的载入时间是不一样的。...无论静态库,还是动态库,都是由.o文件创建的。因此,我们必须将源程序hello.c通过gcc先编译成.o文件。...创建文件冗余信息 -c 创建静态库文件 编译静态库 在编译成静态库之前,我们需要将源文件编译一下,生成一个 .o 文件的目标文件。...比如我们生成的静态库文件是libhello.a 需要编译的文件是main.c。编译命令如下: gcc main.c -L .

8.5K43

DS静态查找之顺序索引查找

题目描述 给出一个队列和要查找的数值,找出数值在队列中的位置,队列位置从1开始 要求使用顺序索引查找算法,其中索引表查找和块内查找都采用不带哨兵、从头开始的顺序查找方法。...表示主表有n个数据 第二行输入n个数据,都是正整数,用空格隔开 第三行输入k,表示主表划分为k个块,k也是索引表的长度 第四行输入k个数据,表示索引表中每个块的最大值 第五行输入t,表示有t个要查找的数值...第六行起,输入t个数值,输入t行 输出 每行输出一个要查找的数值在队列的位置和查找次数,数据之间用短划线隔开,如果查找不成功,输出字符串error 输入样例1 18 22 12 13 8 9 20...顺序索引查找。 首先建立索引表,即两个数组,或者一个结构体数组,用来装关键字,即一个小分块里面最大的数值,还要装关键字对应的小分块在队列里面的起始位置。 关键字由题目给出。...然后到了查找部分: 其实就是部分顺序查找,先在索引表里面查找出在哪个子块里面,然后到子块里面顺序查找

13320

C语言】通讯录《静态内存版本》

修改指定通讯录人的信息 排查通讯录当中人员的信息 ✨模块化代码实现 test.c address_book.c  address_book.h  ✨最后✨ ---- ---- ✨前言   ✨本篇博客会带大家如何去自己实现一个通讯录的一个程序代码...模块化编程:把各个模块的代码放在不同的.c文件里,在.h文件里提供外部可调用函数的声明,其它.c文件想使用其中的代码时,只需要#include "XXX.h"文件即可。...模块化编程:把各个模块的代码放在不同的.c文件里,在.h文件里提供外部可调用函数的声明,其它.c文件想使用其中的代码时,只需要#include "XXX.h"文件即可。...比较字符串 if (strcmp(pc->date[i].name, name) == 0) { return i;//返回下标 } } return -1; } 在这里我们用静态局部变量... static 修饰函数↓ 函数被静态 (static) 修饰函数也是在其他的源文件是不能被使用的,只能在源文件当中去进行使用 !

89150

数据结构:图文详解 - 动态查找静态查找、散列查找

前言 查找是 数据结构中的重要操作 今天,我将主要讲解介绍 查找的相关知识,如查找算法等,希望你们会喜欢。 ---- 目录 ? ---- 1....查找 需求场景 对于不同的查找需求场景,会采用不同的查找类型,最终采用的查找方式(查找算法)也有所不同 具体如下 ? 下面,将根据不同的查找需求类型,讲解对应的查找算法 ---- 3....静态查找 定义:仅作 查找操作 面向的数据结构:静态查找表 算法:顺序查找、有序查找、线性索引查找 具体介绍如下 3.1 顺序查找 具体介绍如下 ?...3.2 有序查找 主要算法有:二分查找、插值 & 斐波那契 本文 主要介绍 = 二分查找(也称:折半查找) 定义 ?...:插值查找 & 斐波那契查找

2K30

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

✨作者:@平凡的人1 ✨专栏:《C语言从0到1》 ✨一句话:凡是过往,皆为序章 ✨说明: 过去无可挽回, 未来可以改变 ---- 二分查找 在有序数组中查找具体的某个数字n,...我们一般从中间元素开始找,查一次去掉一半数字,这种方法我们给它取名为折半查找即为二分查找,效率大大提高!怎么理解呢?...如果有2的32次方个数字,我们最多只需查找32次,而一个一个数运气不好却是2的32次方次。...如果查找的元素小于arr[mid],这说明查找的元素在中间元素的左边,这时候最右边元素right = mid-1,同理,如果查找的元素大于arr[mid],这说明了查找元素在中间元素的右边,这时候最左边元素...left = mid+1.如果出现left>right的情况,这也就说明了数组中并没有存在查找的元素。

95330
领券