计蒜客NOIP2017提高组模拟赛(五)day2-蚂蚁搬家
传送门
这题可以用线段树来维护
#include<cstdio>
#include<cstdlib>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<map>
#include<set>
#include<queue>
#include<vector>
#define INF 0x7f7f7f7f
#define pii pair<int,int>
#define ll long long
#define MAXN 500005
#define DEBUG 1
using namespace std;
int read(){
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if('-'==ch)f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int n,T;
int a[MAXN];
int dat[MAXN*];
void build(int k,int L,int R){
if(L+==R){
dat[k]=a[L];
return;
}
build(k<<,L,(L+R)>>);
build(k<<|,(L+R)>>,R);
dat[k]=max(dat[k<<],dat[k<<|]);
}
void change(int a,int k,int L,int R,int x){
if(L+==R){
dat[k]-=x;
return;
}
int mid=(L+R)/;
if(a<mid){
change(a,k<<,L,mid,x);
}
else{
change(a,k<<|,mid,R,x);
}
dat[k]=max(dat[k<<],dat[k<<|]);
}
int ask(int a,int k,int L,int R){
if(L+==R){
return dat[k];
}
int mid=(L+R)/;
if(a<mid){
return ask(a,k<<,L,mid);
}
else{
return ask(a,k<<|,mid,R);
}
}
int Lfind(int a,int b,int k,int L,int R,int x){
if(b<=L||R<=a||dat[k]<x){
return -;
}
if(L+==R){
return L;
}
int t=Lfind(a,b,k<<|,(L+R)>>,R,x);
if(t!=-){
return t;
}
t=Lfind(a,b,k<<,L,(L+R)>>,x);
return t;
}
int Rfind(int a,int b,int k,int L,int R,int x){
if(b<=L||R<=a||dat[k]<x){
return -;
}
if(L+==R){
return L;
}
int t=Rfind(a,b,k<<,L,(L+R)>>,x);
if(t!=-){
return t;
}
t=Rfind(a,b,k<<|,(L+R)>>,R,x);
return t;
}
void init(){
n=read();T=read();
for(int i=;i<=n;i++){
a[i]=read();
}
build(,,n+);
}
void debug(int k,int L,int R){
if(L+==R){
printf("%d ",dat[k]);
return;
}
debug(k<<,L,(L+R)>>);
debug(k<<|,(L+R)>>,R);
}
void solve(){
for(int i=;i<=T;i++){
// debug(1,1,n+1);
// printf("\n");
int x=read(),y=read();
if(dat[]<x){
printf("-1\n");
continue;
}
if(ask(y,,,n+)>=x){
change(y,,,n+,x);
printf("%d\n",y);
continue;
}
int tL=Lfind(,y-+,,,n+,x);
int tR=Rfind(y+,n+,,,n+,x);
if(-==tL||-==tR){
tR=(tL==-?tR:tL);
}
else if(y-tL<=tR-y){
tR=tL;
}
change(tR,,,n+,x);
printf("%d\n",tR);
}
// debug(1,1,n+1);
// printf("\n");
}
int main()
{
// freopen("data.in","r",stdin);
// freopen("my.out","w",stdout);
init();
solve();
return ;
}
计蒜客NOIP2017提高组模拟赛(五)day2-蚂蚁搬家的更多相关文章
- 计蒜客NOIP2017提高组模拟赛(三)day1
火山喷发 火山喷发对所有附近的生物具有毁灭性的影响.在本题中,我们希望用数值来模拟这一过程. 在环境里有 n 个生物分别具有 A1,A2,⋯,An点生命值,一次火山喷发总计 MM 轮 ...
- 计蒜客NOIP2017提高组模拟赛(四)day1
T1:小X的质数 小 X 是一位热爱数学的男孩子,在茫茫的数字中,他对质数更有一种独特的情感.小 X 认为,质数是一切自然数起源的地方. 在小 X 的认知里,质数是除了本身和 1 以外,没有其他因数的 ...
- 计蒜客NOIP2017提高组模拟赛(五)day1-展览
传送门 发现这题选或不选对状态的优劣程度不会产生影响,如果已经确定了两个数a和b,那么最优的首项和公比也都是唯一确定的, 与对于后面的数x,加进去也好不加进去也好,首项和公比依旧是原来的 于是我们用尺 ...
- 计蒜客NOIP2017提高组模拟赛(五)day1-机智的 AmyZhi
传送门 很水的题目啦QAQ #include<cstdio> #include<cstdlib> #include<algorithm> #include<c ...
- 计蒜客NOIP2017提高组模拟赛(五)day2-成绩统计
传送门 用hash,因为map的复杂度可能在这题中因为多一个log卡掉,但是hash不会 可能因为这个生成的随机数有循环的情况,不是完全均匀的 而且这题hash表的长度也可以开的很大 #include ...
- 计蒜客NOIP2017提高组模拟赛(三)day2-数三角形
传送门 这题有点坑啊 设A为两边颜色不同的角,B为两边颜色相同的角 那么考虑三种三角形:异色,同色,其他 对于任何一个异色三角形,一定会有三个颜色不同的角, 对于任何一个同色三角形,一定会有零个颜色不 ...
- 计蒜客NOIP2017提高组模拟赛(三)day2-直线的交点
传送门 简单几何+逆序对 发现当两条直线甲乙与平板的交点在上面甲在较左的位置,那么下面甲在较右的位置就可以相交 然后把上面的位置排下序,下面离散化+树状数组即可 #include<cstdio& ...
- 计蒜客NOIP2017提高组模拟赛(三)day2-小区划分
传送门 dp,注意边界 #include<cstdio> #include<cstdlib> #include<algorithm> #include<cst ...
- 计蒜客 NOIP 提高组模拟竞赛第一试 补记
计蒜客 NOIP 提高组模拟竞赛第一试 补记 A. 广场车神 题目大意: 一个\(n\times m(n,m\le2000)\)的网格,初始时位于左下角的\((1,1)\)处,终点在右上角的\((n, ...
随机推荐
- 实验MyOD
实验MyOD 编写MyOD.java 用java MyOD XXX实现Linux下od -tx -tc XXX的功能 提交测试代码和运行结果截图,加上学号水印,提交码云代码链接. 代码如下: (刚开始 ...
- Alpha冲刺No.3
冲刺Day3 一.站立式会议 终于我们遇到了我们最艰难的时候,组员也反映每天做的事情越来越少,出现了问题越来越多. 人太少,时间太少,我们没有办法一个人花足够多的时间去钻研统一个问题,或许是所以组员的 ...
- 201621123068 Week04-面向对象设计与继承
1. 本周学习总结 1.1 写出你认为本周学习中比较重要的知识点关键词 答:继承.多态.重载.关键字.父类与子类 1.2 尝试使用思维导图将这些关键词组织起来. 2. 书面作业 1. 面向对象设计(大 ...
- STL常用整理
S T L Sting: << 判断拼音序 size length 字符串长度 str[n] 代表字符串中的一个字符 可用作左值 string::size_type 用于表示字符串长度计量 ...
- 构建微服务开发环境4————安装Docker及下载常用镜像
[内容指引] 下载Docker: Mac下安装Docker: Windows下安装Docker; 下载常用docker镜像. 一.下载Docker 1.Mac适用Docker下载地址:https:// ...
- 安装CentOS7,连接mysql提示密码错误
1.grep 'temporary password' /var/log/mysqld.log 如果上面命令没有查看到密码 2.修改my.cnf文件.在mysqld下加入skip-grant-tabl ...
- Solaris 11 system package 安装与更新(如:assembler)
最近在VirtualBox虚拟机中导入了Solaris 11.3.在里面安装Oracle数据库时,先行条件检查没通过,提示缺少程序包assembler. 在网上看了许多,这方面的信息还比较少.最后在O ...
- 新概念英语(1-115)Knock! Knock!
Lesson 115 Knock, knock! 敲敲门! Listen to the tape then answer this question. What does Jim have to dr ...
- Docker学习笔记 - Docker容器之间的连接
学习目标: 容器之间可以相互连接访问:: --link redis:redisAlias 准备工作 FROM ubuntu:14.04 RUN apt-get install -y ping RUN ...
- python学习之路01
python自己也自学过一段时间了,看过视频,也买过几本基础的书来看,目前为止对于一些简单的代码还是可以看懂,但是自己总是觉得缺少些什么,可能是缺少系统化的学习,也可能是缺少实际项目经验,对于这些缺少 ...