算法家族之一——二分法

目录

大家好,我叫 这是我58,现在,请看下面的算法。

算法

c 复制代码
#define _CRT_SECURE_NO_WARNINGS 1//<--预处理指令
#include <stdio.h><--也是预处理指令
int main() {
	int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };//<--在哪里查
	int i = 1;//<--需要查的数
	int right = sizeof arr / sizeof arr[0]-1;
	int left = 0;
	int mid = 0;
	while (left <= right) {
		mid = (left + right) / 2;
		if (arr[mid] < i) { left = ++mid; }
		else if (arr[mid] > i) { right = --mid; }
		else {
			printf("i(%d)在arr数组里的第%d个位置",i,mid);
			break;
		}
		if (left > right) { printf("在arr数组里,没有"i"这个数字"); }
	}
	return 0;
}

相信大家都对这个算法不陌生吧,没错!这个算法就是我们的二分法!那么,有的人可能就不相信这个算法能正确地运行起来了,现在,如果你是这些人中的其中一个的话,就先看一下下面的内容再说吧。而且,还有这个算法的流程图呢!

算法的打印效果

如果算法里的整型"i"为1

i(1)在arr数组里的第0个位置

如果算法里的整型"i"为11

在arr数组里,没有"i"这个数字

算法的流程图

是 否 是 否 在这之中有"break" 是 是 否 否 开始 定义宏"_CRT_SECURE_NO_WARNINGS"为1 导入头文件stdio.h 定义一个有十个整形的arr数组,里面初始化为{1,2,3,4,5,6,7,8,9,10} 定义整型i为你需要查找的数 定义整型right为整型数组arr的大小除以整型数组arr中的第0项 定义整型left和mid为0 把mid设为(整型left+整型right)*2的值 arr[mid]小于i? 把left设为mid加1之后的结果 arr[mid]大于i? 把right设为mid减1之后的结果 输出"i(%d)在arr数组里的第%d个位置"(第一个"%d"代入整型i,第二个"%d"代入整型mid) 结束 left大于right? 输出"在arr数组里,没有"i"这个数字" left小于等于right?

算法的实际应用

在刚才看完上面的内容后,你可能觉得这个算法只要没记牢就不知道怎么写了,但是,刚开始的确是这样的,可是在后来,你只要年复一年,日复一日地写这个算法,等到后来啊,就基本能够在没有看这个算法的时候写出这个算法了,并且,在能够在没有看这个算法的时候写出这个算法的时候,你就可以更方便地做下面的三件小事了。

  1. 用来求方程的近似值,就比如在公式" f ( x ) = l n ( x ) + 2 x − 6 f(x)=ln(x)+2x-6 f(x)=ln(x)+2x−6"中,只用了4次二分法就精确到了0.1。[1](#1)[2](#2)
  2. 用来更快速地修好电路、水管、气管(只要用几次二分法,就能精准地查找并修好电路、水管或者气管的故障了)。[2](#2)
  3. 用来更快地找出次品,就比如在12个从外表上来看几乎一模一样的球中,有一个次品球,这个次品球比其他球略轻,而只要用几次二分法,就可以较快 地用天平找出那个次品球。[3](#3)[2](#2)

总结

在看完这篇博客之后,我想你应该爱上了算法家族之一------二分法了吧。那么,如果你喜欢上了算法家族之一------二分法的话,可以评论或者投票来互动一下我哦。


  1. 选自搜狗问问中的名叫"用二分法求函数f(x)=lnx+2x-6在区间(2,3)零点近似值,至少经过(  )次二分后精确度达到0.1.A.2"的问题 ↩︎

  2. ↩︎ ↩︎ ↩︎

  3. 选自百度文库中的其中一篇"二分法在生活中的应用." ↩︎

相关推荐
Moonbit10 分钟前
MGPIC 初赛提交倒计时 4 天!
后端·算法·编程语言
Miraitowa_cheems27 分钟前
LeetCode算法日记 - Day 98: 分割回文串 II
数据结构·算法·leetcode·深度优先·动态规划
立志成为大牛的小牛33 分钟前
数据结构——三十九、顺序查找(王道408)
数据结构·学习·程序人生·考研·算法
Shylock_Mister37 分钟前
弱函数:嵌入式回调的最佳实践
c语言·单片机·嵌入式硬件·物联网
2301_8079973838 分钟前
代码随想录-day30
数据结构·c++·算法·leetcode
攒钱植发1 小时前
嵌入式Linux——“大扳手”与“小螺丝”:为什么不该用信号量(Semaphore)去模拟“完成量”(Completion)
linux·服务器·c语言
爱代码的小黄人1 小时前
一般角度的旋转矩阵的推导
线性代数·算法·矩阵
ゞ 正在缓冲99%…1 小时前
leetcode1771.由子序列构造的最长回文串长度
数据结构·算法·leetcode
多喝开水少熬夜2 小时前
堆相关算法题基础-java实现
java·开发语言·算法
锂享生活2 小时前
论文阅读:铁路车辆跨临界 CO₂ 空调系统模型预测控制(MPC)策略
论文阅读·算法