蓝桥杯备赛 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

相关文章

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

C#基础之委托详解(Delegate)

《C#基础之委托详解(Delegate)》:本文主要介绍C#基础之委托(Delegate),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 委托定义2. 委托实例化3. 多播委托(Multicast Delegates)4. 委托的用途事件处理回调函数LINQ

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑