资讯专栏INFORMATION COLUMN

《C语言入门》简单有序数组二分查找代码实现

mozillazg / 3684人阅读

摘要:目录简单原理代码实现简单原理想必学过语言的各位都听说过二分查找的算法,今天我就给各位萌新介绍一下二分查找的简单原理和代码实现。

目录

1.简单原理

2.代码实现

1.简单原理

想必学过C语言的各位都听说过二分查找的算法,今天我就给各位萌新介绍一下二分查找的简单原理和代码实现。

我们使用数组的方式实现二分查找的目标,我们取一串有序数组的中间数组元素,再将此数组元素大小与查找数组比较,再判断是否找到和下一查找区间。使用这种方式可以大大提高我们算法的效率,相比与遍历数组的方法减少了查找次数,也减少了查找时间。下面我们介绍具体代码实现。

2.代码实现

我们先设置一个有序数组,如下所示

int arr[] = { 1,2,3,4,5,6,7,8,9,10,11,12,13 };

接下来我们利用sizeof的方式算出数组长度大小,并且初始第一次查找的下标left和right(注意,最后一个数组下标为数组长度-1),如下图所示

int sz = sizeof(arr) / sizeof(arr[0]);	int left = 0;	int right = sz - 1;

我们再设置一个mid值,作为与被查找数据比较的对象,我们在循环体中将这个值赋为(left+right)/2。重点!!重点!!重点!!我们将两者比较后需要调整left和right的值。若查找数值与mid相等,则此mid下标就是需要查找数值的位置,若查找数值大于mid,我们将left重新赋值为mid+1,若查找数值小于mid,则将right赋值为mid-1,我们将此算法用在一个while循环中,若left<=right证明数组中还存在待查找元素,所以我们使用这一条件作为循环判断条件。下面是全部代码。

int main(){	int arr[] = { 1,2,3,4,5,6,7,8,9,10,11,12,13 };	int sz = sizeof(arr) / sizeof(arr[0]);	int left = 0;	int right = sz - 1;	int a = 0;	int mid = 0;	scanf("%d", &a);	while (left <= right)	{		mid = (right + left) / 2;		if (a > arr[mid])			left = mid + 1;	    if (a < arr[mid])			right = mid - 1;		if(a==arr[mid])		{			printf("找到了,下标是%d", mid);			break;		}	}	if (left > right)		printf("找不到了");	return 0;}

感谢大家的阅读,欢迎各位点赞评论,互关互助,有赞必回,祝各位万事如意。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/124775.html

相关文章

  • 算法入门

    摘要:算法的运行时间用大表示法表示。事实上还有另一种算法即也就是阶乘算法。五选择排序算法在理解选择排序算法的原理之前,我们需要了解大表示法,数组与链表等概念。这种办法,我们暂且称之为预留座位。 一.算法的定义 任何代码片段都可以被称作是算法,这也就是说算法其实就是完成一组任务的指令.算法的优点在于要么速度很快,要么解决一些很有趣的问题,要么兼而有之.并且算法可以应用于任何编程语言中. 二.什...

    xingqiba 评论0 收藏0
  • 二分查找

    摘要:正文二分查找关于二分查找法二分查找法主要是解决在一堆数中找出指定的数这类问题。用二分查找法找寻上界与精确查找不同之处在于,精确查找分成三类大于,小于,等于目标数。 由一道题目引出的: 题目描述 给定一个有序的数组,查找某个数是否在数组中,请编程实现。 分析与解法 一看到数组本身已经有序,我想你可能反应出了要用二分查找,毕竟二分查找的适用条件就是有序的。那什么是二分查找呢? 二分查找可以...

    jerryloveemily 评论0 收藏0
  • 插入排序就这么简单

    摘要:插入排序就这么简单从上面已经讲解了冒泡和选择排序了,本章主要讲解的是插入排序,希望大家看完能够理解并手写出插入排序的代码,然后就通过面试了如果我写得有错误的地方也请大家在评论下指出。 插入排序就这么简单 从上面已经讲解了冒泡和选择排序了,本章主要讲解的是插入排序,希望大家看完能够理解并手写出插入排序的代码,然后就通过面试了!如果我写得有错误的地方也请大家在评论下指出。 插入排序介绍 来...

    Forest10 评论0 收藏0
  • Python 二分查找与 bisect 模块

    摘要:对于大数据量,则可以用二分查找进行优化。有一个模块,用于维护有序列表。和用于指定列表的区间,默认是使用整个列表。模块提供的函数可以分两类只用于查找,不进行实际的插入而则用于实际插入。 Python 的列表(list)内部实现是一个数组,也就是一个线性表。在列表中查找元素可以使用 list.index() 方法,其时间复杂度为O(n)。对于大数据量,则可以用二分查找进行优化。二分查找要求...

    URLOS 评论0 收藏0
  • 数据结构与算法——二分查找

    摘要:所以,二分查找较适用于一次排序,多次查找的数据。面对大量的数据,二分查找方能体现其优势。 1. 二分查找的思想 二分查找是一种使用十分普遍的查找算法,其基本的思路也非常的简单,在一个有序的数据集合中,我们想要查找某个数据,直接取最中间的那个数据,将它和要找的数据进行比较,如果较大,则在更大的那个数值区间继续取中间值查找,反之亦然。 例如我们要在一个有序的集合里[1,3,5,6,7,8,...

    boredream 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<