Peter算法小课堂—区间模型

Peter Pan来啦……

最大不重叠区间数

二话不说,先来一道题

大家想想怎么贪心?我们可以将每一个美食摊位抽象成一个区间,区间左端点为开始排队时间,右端点为结束排队时间。其中,时间信息可以用数轴表示。

额……我们先给出一个错误的贪心

大家想想有没有反例?我将这种反例称之为“锁结构”,如下图

按照上面的贪心法,我们应该选粉色的时间段,但是呢?我们能找到更优的选法,即两端红色的时间段。那么,正确的贪心怎么做的呢?

我们来个证明:我们要最多的不重叠,我们就要腾出时间留给后面的任务,换句话说就要前面的任务早点结束,于是QED。大家尝试做一做。

#include <bits/stdc++.h>
using namespace std;
const int N=109;
int n,x,i,ans;
struct food{int s,t;
};
bool cmp(const food& a,const food& b){return a.t<b.t;
}
food d[N];
int main(){cin>>n;for(i=0;i<n;i++) cin>>d[i].s;for(i=0;i<n;i++) cin>>d[i].t;sort(d,d+n,cmp);x=-1;ans=0;for(i=0;i<n;i++)if(d[i].s>=x){ans++;x=d[i].t;}cout<<ans<<endl;return 0;
}

不重叠区间最少分组数

看着标题好像有点难懂,来道题吧

我们依然可以把每门课抽象成一个区间

这个贪心有点难,证明也很奇怪,所以,我打成图。

具体证明见后。

证明

浅谈信息学竞赛中的区间问题.docx-综合论文-在线文档投稿赚钱网 (book118.com)

结束啦

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux第49步_移植ST公司的linux内核第1步_获取linux源码

已知ST公司的linux源码路径&#xff1a; /home/zgq/linux/atk-mp1/stm32mp1-openstlinux-5.4-dunfell-mp1-20-06-24/sources/arm-ostl-linux-gnueabi/linux-stm32mp-5.4.31-r0 1、创建“my_linux”目录 打开第1个终端 输入“ls回车” 输入“cd linux/回车”&#xff0c;切换…

分享87个jQuery特效,总有一款适合您

分享87个jQuery特效&#xff0c;总有一款适合您 87个jQuery特效下载链接&#xff1a;https://pan.baidu.com/s/1H9kH2qrL-AHFn3jDlNvTFw?pwd8888 提取码&#xff1a;8888 Python采集代码下载链接&#xff1a;采集代码.zip - 蓝奏云 学习知识费力气&#xff0c;收集整理…

C#,数值计算,矩阵的行列式(Determinant)、伴随矩阵(Adjoint)与逆矩阵(Inverse)的算法与源代码

本文发布矩阵&#xff08;Matrix&#xff09;的一些初级算法。 一、矩阵的行列式&#xff08;Determinant&#xff09; 矩阵行列式是指矩阵的全部元素构成的行列式&#xff0c;设A(a)是数域P上的一个n阶矩阵&#xff0c;则所有A(a)中的元素组成的行列式称为矩阵A的行列式&…

2024春晚纸牌魔术原理----环形链表的约瑟夫问题

一.题目及剖析 https://www.nowcoder.com/practice/41c399fdb6004b31a6cbb047c641ed8a?tabnote 这道题涉及到数学原理,有一般公式,但我们先不用公式,看看如何用链表模拟出这一过程 二.思路引入 思路很简单,就试创建一个单向循环链表,然后模拟报数,删去对应的节点 三.代码引…

【SpringBoot】Validator组件+自定义约束注解实现手机号码校验和密码格式限制

&#x1f3e1;浩泽学编程&#xff1a;个人主页 &#x1f525; 推荐专栏&#xff1a;《深入浅出SpringBoot》《java对AI的调用开发》 《RabbitMQ》《Spring》《SpringMVC》 &#x1f6f8;学无止境&#xff0c;不骄不躁&#xff0c;知行合一 文章目录 前言一、Cons…

超越‘赞’按钮:Facebook情感智能的突破之路

社交媒体已经成为了我们生活中不可或缺的一部分。我们通过它与朋友、家人和同事保持联系&#xff0c;分享快乐和悲伤&#xff0c;表达意见和观点。然而&#xff0c;长期以来&#xff0c;我们只能通过简单的“赞”按钮来回应他人的帖子。这种单一的反馈方式无法真正展现我们复杂…

【Tauri】(2):使用Tauri应用开发,使用开源的Chatgpt-web应用做前端,使用rust 的candle做后端,本地运行小模型桌面应用

视频演示地址 https://www.bilibili.com/video/BV17j421X7Zc/ 【Tauri】&#xff08;2&#xff09;&#xff1a;使用Tauri应用开发&#xff0c;使用开源的Chatgpt-web应用做前端&#xff0c;使用rust 的candle做后端&#xff0c;本地运行小模型桌面应用 1&#xff0c;做一个免…

编写Makefile

现在我们将创建一个程序&#xff0c;该程序能够读取次位码文件并打印其中定义的函数名称&#xff0c;以及它们的基本块数&#xff0c;从而显示LLVM库的易用性 什么是Makefile&#xff1f; C语言中&#xff0c;我们使用visual studio开发软件时候&#xff0c;写程序开始时候都…

复旦TravelPlanner让大语言模型挑战旅程规划

引言&#xff1a;探索语言智能的新疆界——旅行规划 在人工智能的发展历程中&#xff0c;规划一直是核心追求之一。然而&#xff0c;由于缺乏人类水平规划所需的多种认知基础&#xff0c;早期的AI代理主要集中在受限的环境中。随着大语言模型&#xff08;LLMs&#xff09;的出…

vue3-应用规模化-路由和状态

客户端 vs. 服务端路由 服务端路由指的是服务器根据用户访问的 URL 路径返回不同的响应结果。当我们在一个传统的服务端渲染的 web 应用中点击一个链接时&#xff0c;浏览器会从服务端获得全新的 HTML&#xff0c;然后重新加载整个页面。 然而&#xff0c;在单页面应用中&…

python伯努利多项式

文章目录 伯努利数和多项式sympy实现 伯努利数是一种在数学、物理和工程中广泛应用的特殊数列&#xff0c;以瑞士数学家雅各布伯努利&#xff08;Jacob Bernoulli&#xff09;的名字命名&#xff0c;并在许多领域中发挥重要作用。在数学中&#xff0c;它们与斐波那契数列、卡塔…

幻兽帕鲁服务器操作系统选择Windows还是Linux?

各有各的优势&#xff0c;幻兽帕鲁Windows&#xff1a;适合新手&#xff0c;快速上手。 而幻兽帕鲁Linux&#xff08;Ubuntu&#xff09;&#xff1a;适合有一定技术基础的小伙伴。 推荐选择Windows系统&#xff0c;用起来更加简单&#xff0c;操作方便。如下图&#xff1a; …