C语言编程之初识数组线性查找和二分查找

 更新时间:2021年09月17日 14:43:02   作者:Booksort  
本篇文章是C语言编程篇,主要为大家介绍C语言编程中数组的线性查找及二分查找分析讲解,有需要的朋友可以借鉴参考下,希望可以有所帮助

先来了解一下什么是查找,
额,好吧,这没什么可了解的,
就是查找数组中的某个元素的位置或是否存在。
就这,没了。直接了解查找算法吧。

线性查找

线性查找与二分查找有些差别。
数组内元素可以是混乱无序的,即没有按顺序储存。这方法很简单,就是从首元素开始,依此向后查找,比较。仅此而已。运用循环,依次对比。
看代码吧。

#include <stdio.h>
int main(void)
{
	int arr[] = { 5,4,6,8,7,9,10,2,3,1 };
	int len = sizeof(arr) / sizeof(arr[0]);//计算数组的元素个数
	int i;
	int n;
	scanf("%d", &n);//输入要查找的元素
	for (i = 0; i < len; i++)
	{
		if (arr[i] == n)
		{
			printf("%d的下标是%d\n", n, i);
			break;//找到后就直接跳出循环
		}
	}
	if (i == len)//因为如果数组元素全部遍历一遍后,都没有i++等于len后,便跳出循环再判断说不存在。
		printf("Don't have number %d\n", n);	
	return 0;
}

线性查找非常简单但,要是数组元素较大,就比较麻烦,毕竟要一个个遍历过去时间复杂度为n。

二分查找

来看看二分查找,就是高中数学学到过的二分法,原理相当简单。但是它只能查找已经排序好的数组,与线性查找相比,有些局限性。
通过比较数组中间数据与目标数据的大小,来判断是在中间数据的左边还是右边,瞬间缩小一半的运算量。再按照这种继续比较,直到找到或找不到为止。

#include <stdio.h>
int main(void)
{
	int n;
	scanf("%d", &n);
	int arr[] = { 1,2,3,4,5,6,7,8,9,10};
	int len = sizeof(arr) / sizeof(arr[0]);
	int left = 0;
	int right = len - 1;
	int mid;
	while (left <= right)
	{
		mid = (left + right) / 2;
		if (arr[mid] > n)
		{
			right = mid-1;
		}
		else if (arr[mid] < n)
		{
			left = mid+1;
		}
		else 
		{
			break;
		}
	}
	if (left <= right)
		printf("%d的下标是%d\n", n, mid);
	else 
		printf("DON't have number %d\n", n);
	return 0;
}
	/*int i = 1;

看张图吧,方便理解与记忆。

在这里插入图片描述

看代码中的,中间元素是5,在5的右边,再把不需要的元素移出比较范围,再,重新设置中间元素,进行比较。

在这里插入图片描述

再拿8进行比较,在8左边。重新规划范围。

在这里插入图片描述

7比6大,则在6右边,继续比较。

在这里插入图片描述

此时,left==right,跟据while循环条件,依旧可以进入循换,但arr[mid]7,说明已经找到那个元素,会break;跳出循环,再判断条件满足left<=right,说明依旧成立,就输出。
否则,如果目标元素是11,则一直会是中间元素的右边。

在这里插入图片描述

再left=MID+1就是10,此时,leftright,循环还没结束,这一次,mid等于10还是比11小,left=10+1,而此时,left>right,不符合条件,循环结束,再判断,不符合条件,就进入else,,说明,11不在数组内。
我第一次写二分查找时,没有写

left = mid+1;
right = mid-1;

而是写

right = mid;
left = mid;

本以为差不多,额,事实上确实差不多,不过当目标数据不在数组内时,要提前判断。如果直接以上面代码的形式,改条件,就会造成,left一直是9,right一直是10,mid也一直是9,无法跳出循环,造成这样的死循环局面。
当写二分查找时一定要切记。
这两个查护,目前就这些。
如有问题,烦请大佬指点一二。
谢谢观看。

以上就是C语言编程之初识数组线性查找和二分查找的详细内容,更多关于C语言数组的资料请关注脚本之家其它相关文章!

相关文章

  • C++ 关键字 inline详细介绍

    C++ 关键字 inline详细介绍

    这篇文章主要介绍了C++ 关键字 inline,有需要的朋友可以参考一下
    2014-01-01
  • 基于QT5的文件读取程序的实现

    基于QT5的文件读取程序的实现

    本文主要介绍了基于QT5的文件读取程序的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • dev-c++创建lib(静态链接库)文件的实现步骤

    dev-c++创建lib(静态链接库)文件的实现步骤

    本文主要介绍了dev-c++创建lib(静态链接库)文件的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • 基于select、poll、epoll的区别详解

    基于select、poll、epoll的区别详解

    本篇文章是对select、poll、epoll之间的区别进行了详细的分析介绍。需要的朋友参考下
    2013-05-05
  • c++加法高精度算法的简单实现

    c++加法高精度算法的简单实现

    下面小编就为大家带来一篇c++加法高精度算法的简单实现。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • C++类型转换归纳总结

    C++类型转换归纳总结

    这篇文章主要介绍了C++类型转换归纳总结,通过本文可以加深读者对于C++变量类型及其相互转换方法的理解,需要的朋友可以参考下
    2014-07-07
  • 一起来了解一下C++的结构体 struct

    一起来了解一下C++的结构体 struct

    这篇文章主要为大家详细介绍了C++的结构体struct,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • C语言读取写入ini配置文件的方法实现

    C语言读取写入ini配置文件的方法实现

    本文主要介绍了C语言读取写入ini配置文件的方法实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • c++中的两种getline用法详解

    c++中的两种getline用法详解

    c++中有2种getline函数,一种在头文件 <istream> 中,是istream类的成员函数;另一种是在头文件 <string> 中,是普通函数。这篇文章主要介绍了c++中的两种getline用法,需要的朋友可以参考下
    2020-02-02
  • C++实现LeetCode(78.子集合)

    C++实现LeetCode(78.子集合)

    这篇文章主要介绍了C++实现LeetCode(78.子集合),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07

最新评论