当前位置: 首页 > news >正文

[二分+差分]AcWing 503 / NOIP2012提高组《借教室》

1.题目说明

在大学期间,经常需要租借教室。

大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室。

教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样。 

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

我们需要处理接下来 n 天的借教室信息,其中第 i 天学校有 ri 个教室可供租借。

共有 m 份订单,每份订单用三个正整数描述,分别为 dj,sj,tj,表示某租借者需要从第 sj 天到第 tj 天租借教室(包括第 sj 天和第 tj 天),每天需要租借 dj 个教室。 

我们假定,租借者对教室的大小、地点没有要求。

即对于每份订单,我们只需要每天提供 dj个教室,而它们具体是哪些教室,每天是否是相同的教室则不用考虑。 

借教室的原则是先到先得,也就是说我们要按照订单的先后顺序依次为每份订单分配教室。

如果在分配的过程中遇到一份订单无法完全满足,则需要停止教室的分配,通知当前申请人修改订单。

这里的无法满足指从第 sj 天到第 tj 天中有至少一天剩余的教室数量不足 dj 个。 

现在我们需要知道,是否会有订单无法完全满足。

如果有,需要通知哪一个申请人修改订单。

2.输入格式

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

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

接下来有 m 行,每行包含三个正整数 dj,sj,tj,表示租借的数量,租借开始、结束分别在第几天。 

每行相邻的两个数之间均用一个空格隔开。

天数与订单均用从 1 开始的整数编号。

3.输出格式

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

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

4.数据范围

1≤n,m≤10的6次方
0≤ri,dj≤10的9次方
1≤sj≤tj≤n

5.输入样例

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

6.输出样例

-1

2

7.思路

本体数据范围较大,使用线段树大概率会超时,所以我们考虑二分+差分的思路来做。

不断二分来调整第一次需要修改的订单编号位置,用差分的思路从0开始加所需教室的数量,当租借数量大于可用的教室数量时即订单无法满足。

不熟悉的差分做法可以参考AcWing797.《差分》(C++,知识点:差分)

8.代码

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;typedef long long LL;const int N = 1000010;int n, m;
int w[N];
int d[N], l[N], r[N];
LL b[N];bool check(int mid)
{memset(b, 0, sizeof b);for (int i = 1; i <= mid; i ++ ){b[l[i]] += d[i];b[r[i] + 1] -= d[i];}for (int i = 1; i <= n; i ++ ){b[i] += b[i - 1];if (b[i] > w[i]) return false;}return true;
}int main()
{scanf("%d%d", &n, &m);for (int i = 1; i <= n; i ++ ) scanf("%d", &w[i]);for (int i = 1; i <= m; i ++ ) scanf("%d%d%d", &d[i], &l[i], &r[i]);int l = 0, r = m;while (l < r){int mid = l + r + 1 >> 1;if (check(mid)) l = mid;else r = mid - 1;}if (r == m) puts("0");else printf("-1\n%d\n", r + 1);return 0;
}

相关文章:

  • YOLOv9有效提点|加入SGE、Ge、Global Context、GAM等几十种注意力机制(四)
  • STM32单片机示例:ETH_DP83848_DHCP_NonOS_Poll_F407
  • 11:日志分析系统ELK|Elasticsearch|kibana
  • Ubuntu将c++编译成.so文件并测试
  • 【程序员养生延寿系列-万人关注的养生指南 4 】
  • 电子电气架构——AUTOSAR架构下EcuM唤醒源事件详解
  • Android在后台读取UVC摄像头的帧数据流并推送
  • 齐天大圣的生活
  • 虚拟化介绍
  • 在Pycharm中运行Django项目如何指定运行的端口
  • Java中的图数据库应用:Neo4j入门
  • 【MySQL】MySQL复合查询--多表查询自连接子查询 - 副本
  • 多益网络这种公司你还敢来吗?
  • selenium中webdriver常用的ChromeOptions参数
  • 从键盘输入5个整数,将这些整数插入到一个链表中,并按从小到大次序排列,最后输出这些整数。
  • #Java异常处理
  • 【159天】尚学堂高琪Java300集视频精华笔记(128)
  • Android 架构优化~MVP 架构改造
  • avalon2.2的VM生成过程
  • Java 内存分配及垃圾回收机制初探
  • Java比较器对数组,集合排序
  • python3 使用 asyncio 代替线程
  • TypeScript实现数据结构(一)栈,队列,链表
  • 基于HAProxy的高性能缓存服务器nuster
  • 基于Javascript, Springboot的管理系统报表查询页面代码设计
  • 模型微调
  • 目录与文件属性:编写ls
  • 如何合理的规划jvm性能调优
  • 《码出高效》学习笔记与书中错误记录
  • # Panda3d 碰撞检测系统介绍
  • (C#)if (this == null)?你在逗我,this 怎么可能为 null!用 IL 编译和反编译看穿一切
  • (delphi11最新学习资料) Object Pascal 学习笔记---第7章第3节(封装和窗体)
  • (笔试题)合法字符串
  • (编程语言界的丐帮 C#).NET MD5 HASH 哈希 加密 与JAVA 互通
  • (分布式缓存)Redis持久化
  • (附源码)springboot高校宿舍交电费系统 毕业设计031552
  • (接口自动化)Python3操作MySQL数据库
  • (六)激光线扫描-三维重建
  • (七)理解angular中的module和injector,即依赖注入
  • (一)ClickHouse 中的 `MaterializedMySQL` 数据库引擎的使用方法、设置、特性和限制。
  • (转)Scala的“=”符号简介
  • ****Linux下Mysql的安装和配置
  • .net core MVC 通过 Filters 过滤器拦截请求及响应内容
  • .NET MAUI学习笔记——2.构建第一个程序_初级篇
  • .NET(C#、VB)APP开发——Smobiler平台控件介绍:Bluetooth组件
  • .NET/C# 避免调试器不小心提前计算本应延迟计算的值
  • .NET/C# 利用 Walterlv.WeakEvents 高性能地定义和使用弱事件
  • .NET分布式缓存Memcached从入门到实战
  • .net下简单快捷的数值高低位切换
  • .net中我喜欢的两种验证码
  • .sh文件怎么运行_创建优化的Go镜像文件以及踩过的坑
  • /run/containerd/containerd.sock connect: connection refused
  • @CacheInvalidate(name = “xxx“, key = “#results.![a+b]“,multi = true)是什么意思
  • @Documented注解的作用
  • @FeignClient 调用另一个服务的test环境,实际上却调用了另一个环境testone的接口,这其中牵扯到k8s容器外容器内的问题,注册到eureka上的是容器外的旧版本...