计蒜客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, ...
随机推荐
- 20162311 实验三 敏捷开发与XP实践 实验报告
20162311 实验三 敏捷开发与XP实践 实验报告 实验内容 一.研究学习IDEA中的Code菜单 使用Code ->Reformate Code功能将以下代码格式化 public clas ...
- 关于FPGA随笔
verilog与c
- JAVA_SE基础——46.引用数据类型变量.值交换[独家深入解析]
需求:定义一个函数交换数组中两个元素的位置. code 1: import java.util.*; class Demo3 { public static void main(String[] ar ...
- Spring+Hibernate+Struts(SSH)框架整合
SSH框架整合 前言:有人说,现在还是流行主流框架,SSM都出来很久了,更不要说SSH.我不以为然.现在许多公司所用的老项目还是ssh,如果改成流行框架,需要成本.比如金融IT这一块,数据库dao层还 ...
- Linq 集合操作符 Except,Intersect,Union
IList<string> s1 = new List<string>() { "One", "Two", "Three&qu ...
- 在WebStorm中启动Angular项目
点击配置 创建 选择命令 package.json 运行 查看运行结果
- 用Vue.js开发微信小程序:开源框架mpvue解析
前言 mpvue 是一款使用 Vue.js 开发微信小程序的前端框架.使用此框架,开发者将得到完整的 Vue.js 开发体验,同时为 H5 和小程序提供了代码复用的能力.如果想将 H5 项目改造为小程 ...
- HTTP协议扫盲(六)InputStream的复用
一.问题提出 在进行网关引擎开发时,获取到一个http请求的inputstream后,可能要多次利用它进行read操作.由于流读过一次就不能再读了,所以需要实现InputStream的复制. 而Inp ...
- 配置ssh无密钥登陆
ssh 无密码登录要使用公钥与私钥. linux下可以用用ssh-keygen生成公钥/私钥对,下面以CentOS为例. 有机器LxfN1(192.168.136.128),LxfN2(192.168 ...
- python 模拟浏览器登陆coursera
import requests import random import string def randomString(length): return ''.join(random.choice(s ...