蓝桥杯备赛 day 2 —— 二分算法(C/C++,零基础,配图)

2024-01-17 23:28

本文主要是介绍蓝桥杯备赛 day 2 —— 二分算法(C/C++,零基础,配图),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

🌈前言:

📁 二分的概念

📁 整数二分

📁 二分的模板

📁 习题

📁 总结


🌈前言:

        这篇文章主要是准备蓝桥杯竞赛同学所写,为你更好准备蓝桥杯比赛涉及的算法知识点。不知道你是否苦恼于不知算法从何学起,苦恼于网上资料稀少,或者复杂难懂,这篇文章就是帮助这部分同学的。

        下面整理了蓝桥杯考点大纲:

               蓝桥杯考点大纲

  

        通过上图,我们知道二分在蓝桥杯比赛中也是比较重要的,所以我们这里就单独写了一篇文章介绍,不仅是因为比较重要,而且二分算法对于刚接触算法的人来说比较复杂,易错点较多,需要不断调试。

📁 二分的概念

        二分,字面意思就是通过判断是否满足条件将区间分成两份。通常的比如大于等于 或者  小于等于.......

📁 整数二分

        对于整数二分,我们可以分成两中类型 :

        1. [L ,Mid - 1] 和 [Mid , R] :所求答案在Mid 右边

        2. [L , Mid ] 和 [Mid + 1 , R] :所求答案在Midz左边

        这两种不同类型的区间,是由于判断条件不同形成的。

📁 二分的模板

        为了大家更好的做题,已经比赛中更好的利用时间,这里提供了整数二分的模板,以及浮点数二分的模板。

1) 区间[L , R] 划分成[L,Mid] 和 [Mid+1 , R]
bool check(int x)
{...    //检查x是否满足某种条件
}
int bearch_1(int l,int r)
{while(l < r){int mid = (l + r ) / 2;if(check(mid))r = mid;elsel = mid + 1;}return 1;
}2) 区间[L , R] 划分成[L,Mid-1] 和 [Mid , R]
bool check(int x)
{...    //检查x是否满足某种条件
}
int bearch_2(int l,int r)
{while(l < r){int mid = (l + r + 1 ) / 2;if(check(mid))l = mid;elser = mid - 1;}return 1;
}

        对于浮点数二分,并不需要关注+-1的问题,所以相对于整数二分来说,简单一些。当然一般来说,对于浮点数二分,我们需要保证精确度在1e-6(1的-6次方)。

bool check((int x)
{...    //检查x是否满足条件
}int bearch_1(int l,int r)
{while(r - l > 1e-6 ){int mid = (l + r ) / 2;if(check(mid))r = mid;elsel = mid ;}return 1;
}

📁 习题

1. 数的范围 789. 数的范围 - AcWing题库

        这道题其实就是一道非常经典的二分题目,首先我们找出左边第一次出现的x,再找出右边第一次出现的x,如果没有找到,则输出-1 -1。

#include <iostream>
#include <cstdio>using namespace std;const int N = 100010;int q[N];
int n,m;int main()
{cin >> n>>m;for(int i=0;i<n;i++)cin>>q[i];while(m--){int x;cin>>x;int l = 0;int r = n-1;while(l < r){int mid = (l + r) >> 1;if(q[mid] >= x)r = mid;elsel = mid + 1;}if(q[l] != x)printf("-1 -1\n");else{printf("%d ",l);r = n-1;while(l < r){int mid = (l + r + 1) >> 1;if(q[mid] <= x)l = mid;elser = mid -1;}printf("%d\n",l);}}return 0;
}

2.数的三次方根 790. 数的三次方根 - AcWing题库

        我们从数据范围当做区间,通过二分找出浮点数n的三次方根。

#include <iostream>
#include <cstdio>using namespace std;int main()
{double x ;cin >> x;double l = -10000,r =10000;while(r -l > 1e-8){double m = (r + l) /2;if(m * m * m >= x)r = m;elsel = m;}printf("%lf",l);return 0;
}

📁 总结

    以上,我们就对二分在蓝桥杯中的知识点进行了讲解,并针对性的讲解了例题,当然这也只是帮你更好的理解这些算法知识,想要学好算法,还需要不断地刷题练习,这里推荐到洛谷,acwing等网站进行练习,比如你看完了这篇文章,做回了例题习题,就可以上这些网站进行想应的练习。

这篇关于蓝桥杯备赛 day 2 —— 二分算法(C/C++,零基础,配图)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/617496

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Spring的基础事务注解@Transactional作用解读

《Spring的基础事务注解@Transactional作用解读》文章介绍了Spring框架中的事务管理,核心注解@Transactional用于声明事务,支持传播机制、隔离级别等配置,结合@Tran... 目录一、事务管理基础1.1 Spring事务的核心注解1.2 注解属性详解1.3 实现原理二、事务事

C++读写word文档(.docx)DuckX库的使用详解

《C++读写word文档(.docx)DuckX库的使用详解》DuckX是C++库,用于创建/编辑.docx文件,支持读取文档、添加段落/片段、编辑表格,解决中文乱码需更改编码方案,进阶功能含文本替换... 目录一、基本用法1. 读取文档3. 添加段落4. 添加片段3. 编辑表格二、进阶用法1. 文本替换2

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

Java中最全最基础的IO流概述和简介案例分析

《Java中最全最基础的IO流概述和简介案例分析》JavaIO流用于程序与外部设备的数据交互,分为字节流(InputStream/OutputStream)和字符流(Reader/Writer),处理... 目录IO流简介IO是什么应用场景IO流的分类流的超类类型字节文件流应用简介核心API文件输出流应用文

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法