算法--贪心

这里写目录标题

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

区间问题

区间选点

引入

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

算法思想

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

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

例题+代码

在这里插入图片描述

一级目录

二级目录

二级目录

二级目录

一级目录

二级目录

二级目录

二级目录

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【MySQL】表的约束 -- 详解

表中一定要有各种约束&#xff0c;通过约束让我们在未来插入数据库表中的数据是符合预期的。约束本质是通过技术手段倒逼程序员插入正确的数据&#xff0c;反过来站在 MySQL 的角度&#xff0c;凡是插入进来的数据都是符合数据约束的。约束的最终目标&#xff1a;保证数据的完整…

ffmpeg的pcm、yuv小知识点

ffmpeg的pcm、yuv小知识点 pcm、yuv保存调用&#xff0c;写个通用工具方法&#xff0c;平时快速保存&#xff0c;和调用方便查看自己bug ffmpeg的AVFrame存储 yuv 调用方法 保存方法 void save_yuv420p_file(unsigned char *y_buf , unsigned char *u_buf,unsigned char *…

Leetcode刷题笔记题解(C++):6. Z 字形变换

思路&#xff1a;遍历时候需要更新步进长度 到达0行的时候步进长度为1&#xff1b;到达最后一行numRows-1行的时候步进长度为-1&#xff1b;代码如下所示&#xff1a; class Solution { public:string convert(string s, int numRows) {//如果字符串长度为1或者所给行数为1 …

嵌入式Qt 实现用户界面与业务逻辑分离

一.基本程序框架一般包含 二.框架的基本设计原则 三.用户界面与业务逻辑的交互 四.代码实现计算器用户界面与业务逻辑 ICalculator.h #ifndef _ICALCULATOR_H_ #define _ICALCULATOR_H_#include <QString>class ICalculator { public:virtual bool expression(const QSt…

qt 软件发布(Windows)

1. 开发环境 QtCreator MSVC编译器 2. 源码编译 生成release或者debug版本的exe可执行文件(x64或x86) 3. windeployqt 打包 ①左下角开始菜单栏找到QT的命令交互对话框&#xff0c;如下图MSVC 2017 64-bit(根据第二步编译的类型选择64位或者32位)。 ②cd 切换到第二步可…

matlab 凸轮轮廓设计

1、内容简介 略 46-可以交流、咨询、答疑 2、内容说明 略 4 取标段的分析 取标装置是贴标机的核心部件之一&#xff0c;是影响贴标质量和贴标精度的重要因素&#xff0c;取标段是通过取标板与标签的相切运动使得涂有胶水的取标板从标签盒中粘取标签纸[4]&#xff0c;理论…

Pyglet控件的批处理参数batch和分组参数group简析

先来复习一下之前写的两个例程&#xff1a; 1. 绘制网格线 import pygletwindow pyglet.window.Window(800, 600) color (255, 255, 255, 255) # 白色 lines []for y in range(0, window.height, 40):lines.append(pyglet.shapes.Line(0, y, window.width, y, colorcolo…

人工智能产生的幻觉问题真的能被看作是创造力的另一种表现形式吗?

OpenAI的首席执行官山姆奥特曼&#xff08;Sam Altman&#xff09;曾声称&#xff0c;人工智能产生的“幻觉”其实未尝不是一件好事&#xff0c;因为实际上GPT的优势正在于其非凡的创造力。 目录 一.幻觉问题的概念 二.幻觉产生的原因 三.幻觉的分类 四.减轻AI的幻觉问题到…

基于springboot+vue的民宿在线预定平台(前后端分离)

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

服务质量目标:SLI,SLO,SLA

如果你要面试运维专家岗/运维架构师/运维经理/运维总监&#xff0c;面试中必然会问到的一个问题就是&#xff1a;“你能保障什么样的SLA&#xff1f;如何去实现你所保障的SLA&#xff1f;” SLA,SLO大家也许也都听说过&#xff0c;也知道几个9的含义&#xff0c;但是细致的去了…

Vulhub 靶场训练 DC-9解析

一、搭建环境 kali的IP地址是&#xff1a;192.168.200.14 DC-9的IP地址暂时未知 二、信息收集 1、探索同网段下存活的主机 arp-scan -l #2、探索开放的端口 开启端口有&#xff1a;80和22端口 3、目录扫描 访问80 端口显示的主页面 分别点击其他几个页面 可以看到是用户…

Base64 编码 lua

Base64 编码 -- Base64 字符表 local base64_chars { A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q, R, S, T, U, V, W, X, Y, Z, a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u, v, w, x, y, z, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,…

猫咪挑食不吃猫粮怎么办?排行榜靠前适口性好的生骨肉冻干分享

猫咪挑食不吃猫粮怎么办现在的猫奴们普遍将自家的小猫视为掌上明珠&#xff0c;宠爱有加。但这样的宠爱有时会导致猫咪出现挑食的问题。那么&#xff0c;猫咪挑食不吃猫粮怎么办&#xff1f;我们该如何应对这种情况呢&#xff1f;今天&#xff0c;我要分享一个既能确保猫咪不受…

Air001 使用内部时钟源,倍频跑48MHz主频例程

Air001 使用内部时钟源&#xff0c;倍频跑48MHz主频例程 ✨根据该芯片手册描述&#xff0c;Air001最高48MHz工作频率。 &#x1f341;Air001使用内部时钟源&#xff0c;固定倍频&#xff08;X2&#xff09;路线&#xff1a; &#x1f6e0;频率和CPU访问存储器周期调整 &…

Ubuntu20.04 ssh终端登录后未自动执行.bashrc

sudo vim ~/.profile输入以下内容 if [ -n "$BASH_VERSION" ]; then if [ -f "$HOME/.bashrc" ]; then . "$HOME/.bashrc" fi fi 执行 source ~/.profile重新测试 其他答案 如果你的~/.bashrc文件在Ubuntu中没有自动生效&#xff0c;…

Tomcat 学习之 Filter 过滤器

目录 1 Filter 介绍 2 Filter 的生命周期 3 Filter 和 FilterChain 4 Filter 拦截过程 5 FilterConfig 6 Filter 使用 1 Filter 介绍 在 Tomcat 中&#xff0c;Filter 是一种用于拦截请求和过滤响应的组件&#xff0c;可以在请求到达 Servlet 之前或响应离开 Servlet 之后…

第15章-IP子网划分

1. 子网划分的需求 1.1 早期的IP地址分类 1.2 产生的问题 1.3 现实的应用场景 2. IP子网划分基础知识 2.1 概念 2.2 子网掩码 3. IP子网划分相关计算 3.1 概述 4. VLSM和CIDR 4.1 VLSM(可变长子网掩码)小 → 大&#xff1b; 4.2 CIDR(无类域间路由)大 → 小&#xff1b; 5.…

Syntax Error: Error: Cannot find module ‘node-sass‘报错解决

1.将项目中的node_modules删除掉 2.npm install重新运行安装命令 3.再npm run serve&#xff08;项目启动命令&#xff09;启动项目即可

LeetCode第二题: 两数相加

文章目录 题目描述示例 解题思路 - 迭代法Go语言实现 - 迭代法算法分析 解题思路 - 模拟法Go语言实现 - 模拟法算法分析 解题思路 - 优化模拟法主要方法其他方法的考虑 ‍ 题目描述 给出两个非空的链表用来表示两个非负的整数。其中&#xff0c;它们各自的位数是按照逆序的方…

DALL·E 3:Improving Image Generation with Better Captions

论文链接&#xff1a;https://cdn.openai.com/papers/dall-e-3.pdf DALLE3 API&#xff1a;https://github.com/Agora-X/Dalle3 官网链接&#xff1a;添加链接描述 DALLE3讲解视频&#xff1a;B站视频 推荐DALLE2的讲解视频&#xff1a;B站&#xff1a;跟李沐学AI 之前精讲的DA…