Vijos P1782 借教室 ( 前缀和&&差分序列)
题目链接:借教室
题意:给出n天得教室数目,m个借教室得单子,按顺序借教室,问哪个单子不满足并输出
分析:可以用线段树做,会T,常数比较大,选择用差分序列维护前缀和,二分答案即可
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std; int ans,n,m,r[],d[],s[],t[],pre[];
//inline int read(){int x=0;char ch=getchar();while(!(ch>='0'&&ch<='9')) ch=getchar();while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();};return x;} int check(int x)
{
int sum=;
memset(pre,,sizeof(pre));
for(int i=;i<=x;i++) pre[s[i]]+=d[i],pre[t[i]+]-=d[i];
for(int i=;i<=n;i++)
{
sum+=pre[i];
if(sum>r[i]) return ;
}
return ;
} int main()
{
scanf("%d %d",&n,&m);
ans=;
for(int i=;i<=n;++i) scanf("%d",r+i);
for(int i=;i<=m;++i) {scanf("%d %d %d",d+i,s+i,t+i);}
int l=,r=m;
while(l<r)
{
int mid=(l+r)>>;
if(check(mid)==) ans=mid,r=mid;
else l=mid+;
}
if(ans) printf("-1\n%d\n",ans);
else puts("");
}
Vijos P1782 借教室 ( 前缀和&&差分序列)的更多相关文章
- VIjos——V 1782 借教室 | | 洛谷——P1083 借教室
		
https://vijos.org/p/1782|| https://www.luogu.org/problem/show?pid=1083 描述 在大学期间,经常需要租借教室.大到院系举办活动,小到 ...
 - NOIP2012 D2 T2 借教室  线段树 OR 二分法
		
题目描述: 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借教室的信息,我们自 ...
 - NOIP2012借教室[线段树|离线 差分 二分答案]
		
题目描述 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要 向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借教室的信息,我们自 ...
 - [NOIP2012] 提高组 洛谷P1083 借教室
		
题目描述 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借教室的信息,我们自然 ...
 - NOIp 2012 #2 借教室 Label:区间修改线段树
		
题目描述 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借教室的信息,我们自然 ...
 - 【NOIP2012】借教室
		
因为本校OJ+1s所以用线段树水过了,不去syz的水库水这题还真不知道线段树过不了= = 原题: 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要 向学校申请借教室.教室的 ...
 - NOIP 2012 T5  借教室 [洛谷P1083]
		
题目描述 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要 向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借教室的信息,我们自 ...
 - NOIP2012 借教室 Splay初探
		
终于把区间操作的Splay搞明白了…… Splay的大致框架是这样的: [代码中的Zig-Zig和Zig-Zag操作其实是可以优化的,实际只需要3次passDown和3次update] templat ...
 - vijos1782借教室
		
描述 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借教室的信息,我们自然希望 ...
 
随机推荐
- 怎么删除"自豪地采用WordPress"
			
wordpress刚刚安装完毕,打开默认的主页,会发现底部有这样的一行文字:“自豪地采用WordPress”.当然了,我们做一个网站,不一定需要这些文字,我们可以删除或者修改这些文字.今天,小编就来教 ...
 - HDU3549  最大流 裸题
			
EK算法 时间复杂度o(n*m*m) 因为有反向边每次bfs时间为 n*m 每次删一条边 最多m次 代码 #include<iostream> #include<string.h& ...
 - GOF 23种设计模式目录
			
经典的gof 23种设计模式,目录大纲查看. 1. Singleton(单例模式) 保证一个类只有一个实例,并提供访问它的全局访问点. 2. Abstract Factory(抽象工厂模式) 提供一个 ...
 - Markdown中插入图片技巧收集
			
在操作Markdown时图片应该是最头痛的一件事! 比如要发送一个md文件给对方,如果附带了图片时,那么就要一大堆文件包括图片发给对方等等,如果使用在线图片,那么这个服务器又是一大痛点,因为你不确定这 ...
 - FlashFXP绿色版
			
http://www.xdowns.com/soft/1/98/2006/Soft_30927.html
 - iOS: 解决Asset Catalog Compile Error - TDDIstiller instance can only be distilled only one time的错误
			
执行命令:rm -rf /Users/<用户名>/Library/Developer/Xcode/DerivedData 然后重新编译项目即可.
 - Linux经常使用命令(更新中)
			
文件类: 1.创建目录:mkdir 例:sudo mkdir test 2.创建空文件:touch 例:sudo touch test.txt 3.删除文件:rm 删除文件不须要确认:rm -f 例: ...
 - 异或巧用:Single Number
			
异或巧用:Single Number 今天刷leetcode,碰到了到题Single Number.认为解答非常巧妙,故记之... 题目: Given an array of integers, ev ...
 - TestNg的工厂測试引用@DataProvider数据源----灵活使用工厂測试
			
之前说过@Factory更适合于同一类型的參数变化性的測试,那么假设參数值没有特定的规律时,我们能够採用@Factory和@DataProvider相结合的方式进行測试 注意要点:请注意測试方法将被一 ...
 - Visual Studio Code Unit Testing
			
1.NUnit project.json { "version": "1.0.0-*", "testRunner": "nunit ...