算法--贪心

news2024/12/23 18:10:02

这里写目录标题

  • 区间问题
    • 区间选点
      • 引入
      • 算法思想
      • 例题+代码
    • 最大不相交区间的数量
      • 算法思想
      • 例题+代码
    • 区间分组
      • 算法思想
      • 例题+代码
  • 一级目录
    • 二级目录
    • 二级目录
    • 二级目录

区间问题

区间选点

引入

在这里插入图片描述
区间问题会给定几个区间,之后要求我们在数轴上选取尽量少的点,使得每个区间内至少包含一个选出的点,如上图,对于这四个区间,我们选择两个点,就可以满足条件

算法思想

在这里插入图片描述
贪心算法使用场景:问题是单峰问题,即他的极值就是最值
基本思路:
对于一个贪心问题,我们没有固定的模版,一般的做法是,我们选出一小块示例,在该示例里面进行推演,推演时按照最理想的解法进行推算,进行尝试,如果在当前这一小部分的实例里是最优解,那么大概率在整个题目中都是最优解,有了初步的推演之后,我们就可以对推演进行正确性的证明。

例如,上图中,
推演的算法是:先将每个区间右端点进行从小到大排序,之后从前往后依次枚举每个区间,如果当前区间内有已经有点,直接pass,如果没有,则选择当前区间的右端点,这样,这段算法在当前部分是合法的
之后进行证明
在这里插入图片描述
我们利用这样的等价原理(如上图)进行证明,
ans是在整个题目中的最优解,cnt是当前推演的算法的解(对于本题而言,解就是点的个数)
首先,对于第一点,由于我们的算法,是合法的,所以,我们的算法主要最次也就是点数比ans要多,因为ans是最优解,所以有ans <= cnt
之后,对于第二点,要证明ans >= cnt ,那么就要证明ans >= cnt的最大值,而cnt的最大值就是所有的区间都没有重复点(如下图),那么根据我们的推演算法,每个区间都要选中一点,且每个区间有且只选一点,那么在这种产生最大值的区间排列情况下,我们的推演算法是最小值,所以,ans 只能 >= ant
(补充:对于该条件,我们可以这样想:只要cnt在“区间排列产出的值是N”这个情况下,仍然合法,cnt的值是N,那么一定有ans >= cnt)
进而证明了 ans == cnt
在这里插入图片描述

例题+代码

在这里插入图片描述
在这里插入图片描述
首先定义了一个结构体,来存储区间
结构体内;
定义 l ,r。分别表示左端点和右端点
之后重载小于号:
bool operator< (const Range &W)const
{
return r < W.r;
}
这个重载放在结构体里面,相当于成员函数,那么该重载只会用在结构体类型变量的小于比较之间,表示一个结构体变量操作数进行“<”操作时,会将与“<”后面的结构体变量传入该重载函数,而操作“<”的结构体变量就是重载函数的this变量
最后结构体后面加了个range[N],表示前面定义结构体的一大坨是一个变量类型,表示是结构体变量类型的数组,相当于 int a;

在main函数中,首先输入n对数据,
这里注意,结构体变量赋值时,使用大括号+逗号进行赋值
之后调用sort函数,对结构体数组里面的变量进行排序,这里是结构体变量排序,会用到结构体定义时的小于号重载
排完序后,定义res=0,用来存储答案,ed=-2e9,-2e9表示负无穷,ed是用来表示当前所选中的点,(注意,当前所选中的点只会保留最新的点,其他点如果被刷下去,会用res++存储,所以是合理的)
之后for循环,对于右端点从小到大的每个区间,我们依次判断情况
直接进行判断 if(range[i].l > ed)如果大于,那么就是区间内没有选中点的情况,那么就记录旧点,更新新点
res++;
ed = range[i].r

其他情况已经包含在内(刚开始第一个区间,肯定会进入到if里面,所以第一个区间的右端点一定有点,之后的区间,如果有,则跳过进行下一个区间的判断,如果没有,进入到if函数里面)

最大不相交区间的数量

算法思想

在这里插入图片描述
我们仍然可以利用上一题的推演,该推演对于本题仍然适用,
进行推演:
对于本题,我们可以将上一题稍作变化,上一题是重合的区间只选一个点,现在我们不选点,重合的区间除去第一个区间以外,其他的都pass,扔掉,而不重合的区间,直接选中该区间的右端点,同时记录该区间选中,这样从小到大进行选择,一定会选出最大数量的区间数
之后进行证明:
仍然是上一题的证明原理,显而易见,我们可以直接整除第二点:因为我们的cnt算法是合法的,而ans算法不仅合法,且是最大值,所以cnt只能 <= ans,即ans >= cnt
而对于第一点,因为cnt算法(即我们自己的推演算法)会保证不重合的区间都计数,所以当N个区间都不重合,那此时cnt算法的值就是N,已经是最大的数量了,因为只有N个区间,而ans、cnt都是合法的,所以,ans只能 <= cnt
(补充:对于该条件,我们可以这样想:只要cnt在“区间排列产出的值是N”这个情况下,仍然合法,cnt的值是N,那么一定有ans >= cnt)
所以,综上,ans == cnt
在这里插入图片描述

例题+代码

在这里插入图片描述
在这里插入图片描述
代码与上题完全一样,上题是记录点的个数,这题是记录区间的个数,而点的个数对应着区间个数,所以代码一样

区间分组

算法思想

在这里插入图片描述
在这里插入图片描述
首先,将所有的区间按左端点从小到大排序
之后,从前往后处理每个区间:
判断能否将其放到某个现有的组中,能放入的条件是:L[ i ] > Max_r(Max_r就是一个组中最新加入的区间的右端点,每次加入新的区间,把Max_r更新一下即可)
对于判断的结果进行讨论:
1.如果不存在这样的组,那么就是所有的组都不满足,那开一个新组,放入该区间
2.如果存在这样的组,将其放进去,并更新当前组的Max_r

证明其正确性:
在这里插入图片描述
同样的,我们需要证明这两点,
首先对于第一点,因为我们的cnt是合法的,而答案ans不仅合法,还是最小值,所有只能有 ans <= cnt
对于第二点,我们可以这样想:只要cnt在“区间排列产出的值是N”这个情况下,仍然合法,那么一定有ans >= cnt,换句话说,判断另一个难以判断的条件时,只要有cnt=N这种情况可以出现,那么我们的推演算法就是合法的
所以,依据这个原理,我们设置所有的区间都是互相重合的,那么就需要分N个组,如果在这种情况下,我们的推演算法的值cnt==N,那么该条件成立,根据推演第一条,“不存在这样的组之后,就新开一个组”,所以会开N个组,所以,第二个条件成立

例题+代码

在这里插入图片描述
在这里插入图片描述
首先在定义结构体Range时,重载小于号时,用L进行重载,因为要用左端点进行排序
之后,main函数中,输入n个l,r
进行排序,(按照重载的小于号排序)
之后,priority_queue<int, vector, greater> heap;(这是小根堆的定义,小根堆是指堆中顶部是堆中所有数据的最小值)
之后,循环n次,
每次循环都拿出数组中的一个数据 r(这是一个Range类型的数据)
之后判断,当堆为空 || heap.top() >= r.l ,(之所以使用top元素进行判断,是因为要用各组的Max_r中最小的一个进行比较,这样如果还是重合,那就新开一个组)那么就新开一个组(表现在代码上就是往栈中推一个右端点)
else {
int t = heap.top(),这一步在该题没啥用,但是可以拿出来堆顶元素,可能其他题会有用
heap.pop(),删除堆顶元素
heap.push(r.r),将新加入的区间的右端点推入堆中
(上面两行代码,缺一不可,删一个加一个,实际上就是实现了更新一个组的Max_r,因为堆中一个元素就代表一个组,元素的值是改组的最右端点)
}
在这里插入图片描述

一级目录

二级目录

二级目录

二级目录

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1472657.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

电脑休眠之后唤不醒

现象&#xff1a;午休时间电脑休眠了&#xff0c;醒来之后发现在密码输入界面&#xff0c;但鼠标键盘没反应。按重启键或电源机重新开机&#xff0c;结果开不了机。 原因&#xff1a;1、内存条脏了&#xff0c;导致内存条读取失败 2、休眠的时候硬盘休眠了&#xff0c;导致按…

欢迎免费申报讯方技术HarmonyOS人才训练营!

在今年1月备受瞩目的鸿蒙生态千帆启航仪式上&#xff0c;华为宣布&#xff1a;HarmonyOS NEXT星河预览版正式面向开发者开放申请&#xff0c;意味着鸿蒙将建立更广泛的生态系统&#xff0c;迎来更多的应用和软硬件产品&#xff0c;加速自我技术迭代&#xff0c;同时推动华为全场…

变革中的容器技术

容器化技术的优点 容器化是一种将应用程序和其所需的依赖项&#xff0c;封装在一个可在任何基础架构上一致运行的轻量级可执行文件&#xff08;即容器&#xff09;的技术。容器化技术可以大大简化应用程序的部署、管理和维护&#xff0c;提高运维效率和可靠性。 容器化技术有…

LeetCode_Java_动态规划(2)(题目+思路+代码)

131.分割回文串 给你一个字符串 s&#xff0c;请你将 s 分割成一些子串&#xff0c;使每个子串都是 回文串 。返回 s 所有可能的分割方案。 回文串 是正着读和反着读都一样的字符串。 示例 1&#xff1a; 输入&#xff1a;s "aab" 输出&#xff1a;[["a&qu…

工具篇-- 定时任务xxl-job的集群部署

文章目录 前言一、xxl-job-admin 集群部署&#xff1a;1.1 部署步骤&#xff1a;1.2 部署求和建议&#xff1a;1.3 集群部署模拟&#xff08;单机&#xff09;&#xff1a; 二、xxl-job 执行器 集群部署&#xff1a;2.1 集群部署要求&#xff1a;2.2 集群部署模拟&#xff1a; …

pthread_exit和pehread_join函数

pthread_exit&#xff1a; 在线程中禁止调用exit函数&#xff0c;否则会导致整个进程退出&#xff0c;取而代之的是调用pthread_exit函数&#xff0c;这个函数只会使一个线程退出&#xff0c;如果主线程使用pthread_exit函数也不会使整个进程退出&#xff0c;不会影响其他线程…

【基础知识】MPP架构和hadoop架构比对

架构比对 简单一句描述。 mpp架构&#xff0c;就是找一群和自己能力差不多的任一起做事&#xff0c;每个人做的事情是一致的。 hadoop架构&#xff0c;就是找一群能力差一些的人&#xff0c;但只需要他们每个人只做一部分工作。 举例说明 一个特色小饭店如何成为连锁餐饮巨…

【国密算法】深入理解国密算法:原理、实践及注意事项

目录 引言 1. 国密算法概述 2. 国密算法的实践应用 2.1 对称加密&#xff08;SM1算法&#xff09; 2.2 非对称加密&#xff08;SM2算法&#xff09; 2.3 哈希算法&#xff08;SM3算法&#xff09; 3. 国密算法的注意事项 结论 引言 国密算法&#xff0c;即中国密码算法…

AI数字人SadTalker实战

1.概述 AI数字人在营销和品牌推广中扮演着至关重要的角色&#xff0c;许多企业和个人正积极利用数字技术来打造属于自己的财富。有没有一种简单而免费的方式来创建自己的数字人呢&#xff1f;本篇博客笔者将为大家介绍如何搭建属于自己的AI数字人。 2.内容 2.1 什么是SadTalker…

内存卡无法读取?这里有救!

一、遭遇内存卡无法读取的困境 在日常生活和工作中&#xff0c;我们越来越依赖电子设备来存储和传输数据。然而&#xff0c;当遇到内存卡无法读取的问题时&#xff0c;很多人会感到困惑和焦虑。无论是重要的工作文件、珍贵的家庭照片&#xff0c;还是其他个人数据&#xff0c;…

基于springboot+vue的音乐网站(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

C++力扣题目 42--接雨水 84--柱状图中最大的矩形

42. 接雨水 力扣题目链接(opens new window) 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 示例 1&#xff1a; 输入&#xff1a;height [0,1,0,2,1,0,1,3,2,1,2,1]输出&#xff1a;6解释&#xff…

C++17之折叠表达式

相关文章系列 深入理解可变参数(va_list、std::initializer_list和可变参数模版) 目录 1.介绍 2.应用 2.1.使用折叠表达式 2.2.支持的运算符 2.3.使用折叠处理类型 3.总结 1.介绍 折叠表达式是C17新引进的语法特性。使用折叠表达式可以简化对C11中引入的参数包的处理&…

原型设计工具Axure RP

Axure RP是一款专业的快速原型设计工具。Axure&#xff08;发音&#xff1a;Ack-sure&#xff09;&#xff0c;代表美国Axure公司&#xff1b;RP则是Rapid Prototyping&#xff08;快速原型&#xff09;的缩写。 下载链接&#xff1a;https://www.axure.com/ 下载 可以免费试用…

windows安装onlyoffice8.0

安装erlang 安装Erlang25.3 下载地址 设置环境变量 ERLANG_HOME C:\Program Files\Erlang OTP Path下设置%ERLANG_HOME%\bin 打开cmd输入erl不报错即可 安装rabbitmq rabbitmq和erlang对应的关系 下载地址 执行完exe文件后&#xff0c;找到安装目录下的sbin&am…

H12-821_77

77.如图所示的交换网络&#xff0c;所有交换机都运行了STP协议&#xff0c;当拓扑稳定后&#xff0c;在以下哪台交换机上修改配置BPDU的发送周期&#xff0c;可以影响STD配置BPDU的发送周期&#xff1f; A.STC B.SWD C.SWA D.SWB 答案&#xff1a;C 注释&#xff1a; 在根桥上…

MATLAB环境下基于超高斯全自动组织学图像的盲彩色反卷积方法

图像盲反卷积问题仅根据模糊图像估计清晰图像和模糊核&#xff0c;也是一个欠定问题且求解更加困难。但图像盲反卷积算法更实际&#xff0c;因为许多情况下&#xff0c;模糊核都是未知或部分已知的。求解盲反卷积问题需要为未知量选择适当的先验模型&#xff0c;以得到清晰图像…

二叉树与堆

目录 1.树概念及结构 1.1树的概念 1.2 树的相关概念 1.3 树的表示 1.4 树在实际中的运用&#xff08;表示文件系统的目录树结构&#xff09; 2.二叉树概念及结构 2.1概念 2.2现实中的二叉树&#xff1a; 2.3 特殊的二叉树&#xff1a; 2.4 二叉树的性质 2.5 二叉树的…

基于springboot+vue的二手图书交易平台(源码+论文)

文章目录 目录 文章目录 前言 一、功能设计 二、功能实现 前台系统功能模块分为 后台系统功能模块分为 三、库表设计 四、论文 前言 在互联网上所有产品的分类信息中&#xff0c;电子类的产品信息无疑是最丰富的&#xff0c;一大批电子资讯类网站从中国互联网诞生初期就开始为…

力扣模板题:回文链表

请牢记检测回文串的模板 /*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* };*/ bool isPalindrome(struct ListNode* head) {int size0;struct ListNode* pointhead;while(point){size;pointpoint->next;}int arr…