线段树(p1083)

news/2025/11/8 18:48:27/文章来源:https://www.cnblogs.com/sadmax11/p/19202873

P1083 [NOIP 2012 提高组] 借教室

题目描述

在大学期间,经常需要租借教室。大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室。教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样。

面对海量租借教室的信息,我们自然希望编程解决这个问题。

我们需要处理接下来 \(n\) 天的借教室信息,其中第 \(i\) 天学校有 \(r_i\) 个教室可供租借。共有 \(m\) 份订单,每份订单用三个正整数描述,分别为 \(d_j,s_j,t_j\),表示某租借者需要从第 \(s_j\) 天到第 \(t_j\) 天租借教室(包括第 \(s_j\) 天和第 \(t_j\) 天),每天需要租借 \(d_j\) 个教室。

我们假定,租借者对教室的大小、地点没有要求。即对于每份订单,我们只需要每天提供 \(d_j\) 个教室,而它们具体是哪些教室,每天是否是相同的教室则不用考虑。

借教室的原则是先到先得,也就是说我们要按照订单的先后顺序依次为每份订单分配教室。如果在分配的过程中遇到一份订单无法完全满足,则需要停止教室的分配,通知当前申请人修改订单。这里的无法满足指从第 \(s_j\) 天到第 \(t_j\) 天中有至少一天剩余的教室数量不足 \(d_j\) 个。

现在我们需要知道,是否会有订单无法完全满足。如果有,需要通知哪一个申请人修改订单。

输入格式

第一行包含两个正整数 \(n,m\),表示天数和订单的数量。

第二行包含 \(n\) 个正整数,其中第 \(i\) 个数为 \(r_i\),表示第 \(i\) 天可用于租借的教室数量。

接下来有 \(m\) 行,每行包含三个正整数 \(d_j,s_j,t_j\),表示租借的数量,租借开始、结束分别在第几天。

每行相邻的两个数之间均用一个空格隔开。天数与订单均用从 \(1\) 开始的整数编号。

输出格式

如果所有订单均可满足,则输出只有一行,包含一个整数 \(0\)

否则(订单无法完全满足)输出两行,第一行输出一个负整数 \(-1\),第二行输出需要修改订单的申请人编号。

输入输出样例 #1

输入 #1

4 3 
2 5 4 3 
2 1 3 
3 2 4 
4 2 4

输出 #1

-1 
2

说明/提示

【输入输出样例说明】

\(1\) 份订单满足后,\(4\) 天剩余的教室数分别为 \(0,3,2,3\)。第 \(2\) 份订单要求第 \(2\) 天到第 \(4\) 天每天提供 \(3\) 个教室,而第 \(3\) 天剩余的教室数为 \(2\),因此无法满足。分配停止,通知第 \(2\) 个申请人修改订单。

【数据范围】

对于 \(10\%\) 的数据,有 \(1\le n,m\le 10\)

对于 \(30\%\) 的数据,有 \(1\le n,m\le 1000\)

对于 \(70\%\) 的数据,有 \(1 \le n,m \le 10^5\)

对于 \(100\%\) 的数据,有 \(1 \le n,m \le 10^6\)\(0 \le r_i,d_j\le 10^9\)\(1 \le s_j\le t_j\le n\)

NOIP 2012 提高组 第二天 第二题

2022.2.20 新增一组 hack 数据

AC代码

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int maxn=1e6+10;
struct tree{ll l,r,lazy,minn;
};tree tr[maxn<<2];
ll a[maxn],n,m;void build(int l,int r,int id){tr[id].l=l;tr[id].r=r;tr[id].lazy=0;if(l==r){tr[id].minn=a[l];return;}else{build(l,(l+r)/2,id<<1);build((l+r)/2+1,r,id<<1|1);}tr[id].minn=min(tr[id<<1].minn,tr[id<<1|1].minn);
}void pushdown(int id){if(tr[id].lazy){tr[id<<1].lazy+=tr[id].lazy;tr[id<<1|1].lazy+=tr[id].lazy;tr[id<<1].minn+=tr[id].lazy;tr[id<<1|1].minn+=tr[id].lazy;tr[id].lazy=0;}
}void update(int l,int r,int id,int v){if(tr[id].l>=l&&tr[id].r<=r) {tr[id].lazy+=v;tr[id].minn+=v;return;}else{pushdown(id);int mid=(tr[id].l+tr[id].r)>>1;if(l<=mid) update(l,r,id<<1,v);if(r>mid) update(l,r,id<<1|1,v);}tr[id].minn=min(tr[id<<1].minn,tr[id<<1|1].minn);
}int main(){cin>>n>>m;for(int i=1;i<=n;i++){cin>>a[i];}build(1,n,1);for(int i=1;i<=m;i++){int v,l,r;cin>>v>>l>>r;update(l,r,1,-v);if(tr[1].minn<0) {cout<<-1<<endl<<i;return 0;}}cout<<0<<endl;return 0;
}

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

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

相关文章

初识PPO

for batch_prompt in prompt_dataset:batch_response = active_model.generate(batch_prompt)batch_data = concat(batch_prompt, batch_response)batch_scores = reward_model(batch_data)batch_all_probs, batch_pro…

[ vmware 连接宿主机代理 ]

# 本文只讲原理,只是技术研究 # 1. Tun 开启 -> 本质开启一张虚拟网卡; 允许局域网连接 # 2. 虚拟机默认走 Nat -> VMnet8 # 3. Tun的网卡开启网络共享,共享给 VMnet8

【Android】六大设计原则 - 教程

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

2025年合肥甲醛检测公司哪家好?专业机构排名与选择指南

摘要 随着人们对室内空气质量的重视程度不断提高,甲醛检测行业在2025年迎来了快速发展期。本文基于市场调研和用户反馈,为您精选五家优质甲醛检测机构,并提供详细对比分析。文末附有专业选择指南和参考表单,助您找…

现今除甲醛机构选哪家?深度分析

摘要 随着室内空气污染问题日益受到关注,除甲醛行业在2025年迎来了快速发展。消费者对靠谱、专业除甲醛服务的需求激增,本文基于权威数据和用户反馈,整理了目前国内除甲醛机构排名前十的榜单,并为读者提供选择指南…

Unity2D 图片支持拖拽和以鼠标中心缩放

引言: 作为一个Unity初学者,遇到了需要实现以鼠标为中心缩放的功能且需要支持拖拽,秉着复用主义的原则,在网上查找了不少博客,要么免费但不能直接拿来使用,要么需要VIP充值获取项目代码,此外,原理且讲解甚少。…

轻松可视化信息的利器——JSON Crack

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

详细介绍:C++微基础备战蓝桥杯string篇10.5

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

[ jupyter conda 环境]

在激活的环境中,可以通过以下命令安装所需的库(包括 NumPy、Pandas、JupyterLab),以及配置自动补全功能,步骤如下: 1. 安装核心库(NumPy、Pandas、JupyterLab) 在激活 myenv 环境后,直接用 conda install 安装…

深入解析:仿mudou——Connection模块(连接管理)

深入解析:仿mudou——Connection模块(连接管理)pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas"…

Linux中查看个人磁盘容量

001、 lfs quota -u s20223040682 /public/home/s20223040682

以太坊私有链搭建与智能合约部署指南 - 教程

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

【学弟向】图的存储与遍历,最短路,连通性 tarjan,树状数组

树状数组 单点修改,前缀查询。 int lbd(int x) {return (x&(-x));} void gai(int x,int c) {for(int i=x;i<=n;i+=lbd(i)) a[i]+=c;} int cha(int x) {int da=0;for(int i=x;i;i-=lbd(i)) da+=a[i];return da;…

2025年11月中国伸缩门制造企业技术实力排行榜TOP5

摘要 随着智慧城市建设的深入推进,2025年中国伸缩门行业迎来技术升级浪潮。智能防夹技术、物联网集成系统和节能驱动技术成为行业新标准,市场需求同比增长23.6%。本文基于企业研发投入、专利数量、客户案例等权威数据…

完整教程:Redis-Zest

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

(数学)好玩但没啥用的解题方法(1)

\[a\geq 0,b\geq 0,a+b=1,求\sqrt{a}+\sqrt{b}的最大与最小值 \]设 \(x=\sqrt{a},y=\sqrt{b}\) ,则\(a+b=1<=>x^2+y^2=1\),是一个单位圆,而 \(\sqrt{a}+\sqrt{b}=x+y\) 。 容易注意到 \(x+y\) 为 \((0,0)\…

2025年11月中国伸缩门厂家综合实力排行榜TOP5

摘要 随着智慧城市建设的深入推进,伸缩门行业在2025年迎来技术升级与市场扩容的双重机遇。本文基于产品性能、技术创新、服务网络及客户案例等维度,对国内主流伸缩门厂家进行综合评估,为政府采购、企业采购提供权威…

我目前所理解的“生成式认知主体”

# 我目前所理解的“生成式认知主体”>前言:[写作能力提升的结构化路径](https://chat.deepseek.com/share/zq67x3d1xpamytl5qp)>在我有打算写关于这个主题的内容前实际上经过了很长时间的 整理思想、理清方向、…

P10627 中暑

题目大意: 有 \(n\) 个盒子,每个盒子有个容量 \(a_{i}\),接下来有 \(m\) 次投球操作。 每次给定一个 \(x\),表示你可以将当前这个球放到第 \(x\) 或者第 \(x + 1\) 个盒子里(前提是他没满),如果两个盒子都满了,…

C语言“变量”与Python“Name”:跨语言核心概念及内存模型辨析

C语言“变量”与Python“Name”:跨语言核心概念及内存模型辨析 摘要:本文针对C语言转Python学习者的认知障碍问题,系统剖析C语言“变量即容器”与Python“名字即指针”的内存模型本质差异。通过理论溯源、源码分析、…