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

查找算法】折半查找

本篇文章将介绍折半查找算法。 文章目录 何为折半查找? 算法实现 递归实现 效率分析 何为折半查找?...上一篇文章介绍了顺序查找算法,我们知道,虽然顺序查找算法适用性高,但效率太低,那么能不能在此基础上继续提高算法的效率呢?...这个时候,折半查找诞生了,它的原理是每次都将待查找的记录所在的区间缩小一半,比如: 若要在该序列中查找元素值4,折半查找是如何做到的呢?...它需要先设置两个游标,一个指向最左边,一个指向最右边: 这两个游标所表示的范围即为查找区间,初始我们在下标为1到10的区间内查找,这个查找也是讲究方法的,不是一个一个地去遍历查找

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

    二分查找折半查找

    二分查找的前提是数据一定要有序,否则一切皆为空谈。通过有序的一段数据使用二分查找较常规遍历查找算法速度要快一些。其中二分查找发有两种实现,一种为常规while循环,另外一种为递归。...若相等,则查找成功。否则利用中间位置将集合分成两个子集。 若中间元素大于目标元素,则在左子集中查找,否则在右子集中查找。 重复以上操作,直至找到要查找的元素,或是直到子集不存在查找的数据。...include #include int binarySearch(int *data, int low, int high, int find) { // 循环进行查找.../ 2; // 判断除2后的下标所对应的数据是否就是我们找的数据 // 如果是则直接返回 if (data[mid] == find) return mid; // 否则判断该下标对应的数据是否大于查找的数据...%d 的值是我们需要的数据 %d:\n”, find, arr[find]); system(“pause”); return 0; } 下图是根据以上代码制作的二分查找的示例图,可参考学习:

    22720

    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

    88720

    科学计数 C语言

    现以科学计数的格式给出实数 A,请编写程序按普通数字表示输出 A,并保证所有有效位都被保留。 输入格式: 每个输入包含 1 个测试用例,即一个以科学计数表示的实数 A。...输出格式: 对每个测试用例,在一行中按普通数字表示输出 A,并保证所有有效位都被保留,包括末尾的 0。...C语言中的%[] %[]的功能是只读入[]内的字符,比如下面我的代码中的%[0-9]就是值只读入0到9这10个数字,碰到其他的字符就停止,如果加上^这个字符,变成%[^],那就是不读入[]内的字符,比如...c.%[0-9]E%c%d",&sign,&n[0],n+1,&signindex,&index); if(sign=='-') printf("-"); if(signindex=='-')...; while(index--) printf("0"); printf("%s",n); } else { for(i=0;n[i];i++) { printf("%c"

    25620

    简单二分查找(binary search)

    mid+1, high, value); } else { return bsearchInternally(a, low, mid-1, value); } } 上面这种思想也就是二分思想...,但是还有就是二分的这种思想的使用场景的局限性还是比较多的 二分依赖的是顺序表结构(数组) 那二分查找能否依赖其他数据结构呢?...所以,如果数据使用链表存储,二分查找的时间复杂就会变得很高 二分针对的是有序数组 二分查找对这一点的要求比较苛刻,数据必须是有序的。如果数据没有序,我们需要先排序。...那针对动态数据集合 数据量太小也是不适合二分的 如果要处理的数据量很小,完全没有必要用二分查找,顺序遍历就足够了。...数据量太大也不适合使用二分, 准确来说数据量太大不适合使用数组存储数据,比如说1GB 的数据,使用数组存储的话,这1GB数据必须是连续的存储,比如你现在剩余内存为1GB 但是这个1GB数据 不一定能存储这

    57710
    领券