论二分的强大(bian tai)性

二分,是个很常见的算法, 它可以提高程序的效率,可能会由O(n ^2)变为O(n log n)。我举个例子,让大家看看二分的优化效果到底有多么的强大!
例:输入一个正整数n,求根号n的值(保留小数点后第五位)

//暴力算法:
#include <iostream>
#include <iomanip>
#include <cmath>
double n;
using namespace std;
int main()
{
	cin >> n;
	for(double i = 1.00; i <= n; i += 0.000001)
	{
		if(abs(i * i - n) <= 0.00001)//如果i的平方减去n的绝对值小于等于0.00001,即i和根号n之间差的比0.00001要小
		{
			cout << fixed << setprecision(5) << i;//输出答案,"fixed << setprecision(5) <<"是用来保留5位小数的
			return 0;//程序拜拜
		}
	}
}
//二分算法:
#include <iostream>
#include <iomanip>
double n, l, r, mid;//l是左指针,r是右指针,mid是中间值
using namespace std;
int main()
{
	cin >> n;
	r = n;//先给右指针赋一个最大值n
	while((r - l) >= 0.0000001)
	{
		mid = (l + r) / 2;//中间值 = (左指针 + 右指针) / 2
		if(mid * mid > n)//如果中间值的平方大于n,即中间值大于根号n
		{
			r = mid;//右指针移到中间
		}
		else//否则
		{
			l = mid;//左指针移到中间
		}
	}
	cout << fixed << setprecision(5) << mid;//输出答案,"fixed << setprecision(5) <<"是用来保留5位小数的
	return 0;//程序拜拜
}

对照两份代码,当n >= 200时, 暴力程序已经炸了。而二分代码,n都爆int了,程序还能很快的运行出来(先不说正确性)。看来,二分真的是很强大(bian tai)的!让我们一起学习二分吧!
小弟的第一篇文章,不喜勿喷。

基于STM32设计的数字示波器全套资料(原理图、PCB图、源代码) 硬件平台: 主控器:STM32F103ZET6 64K RAM 512K ROM 屏幕器:SSD1963 分辨率:480*272 16位色 触摸屏:TSC2046 模拟电路: OP-TL084 OP-U741 SW-CD4051 CMP-LM311 PWR-LM7805 -LM7905 -MC34063 -AMS1117-3.3 DRT-ULN2003 6.继电器:信号继电器 7.电源:DC +12V 软件平台: 开发环境:RealView MDK-ARM uVision4.10 C编译器:ARMCC ASM编译器:ARMASM 连机器:ARMLINK 实时内核:UC/OS-II 2.9实时操作系统 GUI内核:uC/GUI 3.9图形用户接口 底层驱动:各个外设驱动程序 数字示波器功能: 波形发生器:使用STM32一路DA实现正弦,三角波,方波,白噪声输出。 任意一种波形幅值在0-3.3V任意可调、频率在一定范围任意可调、方波占空比可调。调节选项可以通过触摸屏完成设置。 SD卡存储: SD卡波形存储输出,能够对当前屏幕截屏,以JPG格式存储在SD卡上。能够存储1S内的波形数据,可以随时调用查看。 数据传输:用C#编写上位机,通过串口完成对下位机的控制。(1)实现STOP/RUN功能(2)输出波形电压、时间参数(3)控制截屏(4)控制波形发生器(5)控制完成FFT(6)波形的存储和显示 图形接口: UCGUI 水平扫速: 250 ns*、500ns、1μs、5 μs、10μs、50μs、500 μs、5ms 、50ms 垂直电压灵敏度:10mV/div, 20mV/div, 50mV/div, 0.1V/div, 0,2V/div, 0.5V/div, 1V/div,2V/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值