当前位置: 首页 > news >正文

牛刀小试---二分查找(C语言)

题目:在给定的升序数组中查找指定的数字n,并输出其下标

代码举例:

#include <stdio.h>
int main()
{
	int arr[] = { 1,2,3,4,5,6,7,8,9,10 };//给定的升序数组
	int left = 0;//定义左下标
	int right = sizeof(arr) / sizeof(arr[0]) - 1;//定义右下标
	int key = 7;//要找的数字
	int mid = 0;//记录中间元素的下标
	int find = 0;//定义真假,用与判断输出
	while (left <= right)
	{
		mid = (left + right) / 2;//表示中间元素的下标
		if (arr[mid] > key)//中间下标所在元素大于要找的数字
		{
			right = mid - 1;//则右下标改变
		}
		else if (arr[mid] < key)//中间下标所在元素小于要找的数字
		{
			left = mid + 1;//则左下标改变
		}
		else//中间下标所在元素就是要找的数字
		{
			find = 1;//真,找到了
			break;//跳出循环
		}
	}
	//输出
	if (1 == find)
		printf("找到了,下标是%d\n", mid);
	else
		printf("找不到\n");
	return 0;
}

运行结果:

题目解析:

1. 明确概念:

二分查找,也叫折半查找,是一种在有序数组中查找特定元素的算法。它通过比较中间元素和目标值的大小,将查找范围缩小为一半,直到找到目标元素或者查找范围为空。

2. 知其原理(步骤)

 1. 确定搜索范围:首先,需要确定要在哪个区间内进行查找。这可以通过比较目标值与中间元素的大小来确定。如果目标值小于中间元素,则可以确定目标值只可能存在于前半部分;如果目标值大于中间元素,则可以确定目标值只可能存在于后半部分;如果目标值等于中间元素,则可以直接找到目标值。


 2.划分区间:根据目标值与中间元素的比较结果,可以将搜索范围划分为两个子区间。如果目标值小于中间元素,则将搜索范围缩小为前半部分;如果目标值大于中间元素,则将搜索范围缩小为后半部分。

 3.在确定了新的搜索范围后,重复步骤1,2,直到找到目标值。

3. 思路方法:

知道其原理,将其转化为代码,通过定义左右下标,确定搜索范围,通过定义中间元素下标,确定中间元素,通过定义变量key表示所找目标值,通过定义变量flag,用于判断输出;比较目标值与中间元素的大小,根据目标值与中间元素的比较结果,通过左右下标的改变,缩小搜索范围,通过while循环实现重复;最后通过变量flag进行判断输出。

结言:本文将一维数组的使用与循环相结合,实现二分查找,进一步巩固数组和循环相关知识。

相关文章:

  • C#--核心
  • 生信技能36 - 获取染色体短臂、长臂和跨短臂长臂的全部区带列表
  • C#: 结构体 struct 应用笔记
  • sqlserver2012 跨服务器查询
  • 微信公众号注册(详细图文教程)
  • 【Linux】第二十九站:再谈进程地址空间
  • 【架构设计】单体软件向微服务化演变
  • 随机获取某个集合中的某个元素,多次获取时不重复
  • 【论文阅读】Latent Consistency Models (LDMs)、LCM-LoRa
  • 2-认识小程序项目
  • Python网络爬虫进阶:自动切换HTTP代理IP的应用
  • 高纯气体市场调研:预计2029年将达到331亿美元
  • 【K12】Python写串联电阻问题的求解思路解析
  • TinyLog iOS v3.0接入文档
  • 【UE5】交互式展厅数字博物馆交互是开发实战课程
  • Linux下的HTTPS配置:从证书到安全连接
  • 智能小程序小部件(Widget)表单组件属性说明+代码明细
  • springboot整合websocket后启动报错:javax.websocket.server.ServerContainer not available
  • 用matlab解决简单的数学问题
  • Unity3D 服务器逻辑和传输如何分层/解耦详解
  • 最高法、证监会:常态化开展证券纠纷代表人诉讼,降低投资者维权成本
  • 齐白石精品在波士顿展出,“白石画屋”呈现水墨挥洒
  • 美国明尼苏达州发生山火,过火面积超80平方公里
  • 三亚通报救护车省外拉警报器开道旅游:违规违法,责令公司停业整顿
  • 男子退机票被收票价90%的手续费,律师:虽然合规,但显失公平
  • 寒武纪陈天石:公司的产品力获得了行业客户广泛认可,芯片市场有望迎来新增量需求