【CodeForces】【338E】Optimize!
线段树
先搞出来每个a[i]能连多少条边记为w[i]……如果对一组s[i],都满足w[i]-rank[i]>=0则这是一组合法方案,然后线段树维护w[i]-rank[i](第一个元素出去的时候后面所有的rank要-1,加入最后一个元素的时候后面的元素rank+1,建关于a[i]的权值线段树,记得离散化)
线段树维护的时候modify(区间修改)忘加push_down了……so sad
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define rep(i,n) for(int i=0;i<n;++i)
#define F(i,j,n) for(int i=j;i<=n;++i)
#define D(i,j,n) for(int i=j;i>=n;--i)
using namespace std;
typedef long long LL;
inline int getint(){
int r=,v=; char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-')r=-;
for(; isdigit(ch);ch=getchar()) v=v*+ch-'';
return r*v;
}
const int N=,INF=~0u>>;
//#define debug
/********************template*******************/
struct node{
int size,min,add;
}t[N<<];
#define L (o<<1)
#define R (o<<1|1)
#define mid (l+r>>1)
int n,m,len,H,w[N],a[N],b[N],c[N];
void maintain(int o,int l,int r){
if (l==r) return;
t[o].size=t[L].size+t[R].size;
if (t[o].size) t[o].min=min(t[L].min,t[R].min);
else t[o].min=INF,t[o].add=;
}
int ql,qr;
void push_down(int o,int l,int r){
if (!t[o].add) return;
t[L].add+=t[o].add; t[R].add+=t[o].add;
t[L].min+=t[o].add; t[R].min+=t[o].add;t[o].add=;
}
void modify(int o,int l,int r,int num){
if (ql>qr) return;
if (ql<=l && qr>=r) t[o].add+=num,t[o].min+=num;
else{
push_down(o,l,r);
if (ql<=mid) modify(L,l,mid,num);
if (qr>mid ) modify(R,mid+,r,num);
maintain(o,l,r);
}
}
void update(int o,int l,int r,int pos,int rank){
if (l==r){
t[o].size^=;
t[o].min=t[o].size?w[pos]-rank-t[o].size:INF;
}else{
push_down(o,l,r);
if (a[pos]<=mid) update(L,l,mid,pos,rank);
if (a[pos]>mid) update(R,mid+,r,pos,rank+t[L].size);
maintain(o,l,r);
}
}
void out(int o,int l,int r){
printf("%d %d %d %d %d %d\n",
o,l,r,t[o].size,t[o].add,t[o].min);
if (l==r) return;
else {out(L,l,mid); out(R,mid+,r);}
}
inline bool cmp(int x,int y){return a[x]<a[y];}
int main(){
#ifndef ONLINE_JUDGE
freopen("CF338E.in","r",stdin);
freopen("CF338E.out","w",stdout);
#endif
n=getint(); len=getint(); H=getint();
F(i,,len) b[i]=getint();
sort(b+,b+len+);b[len+]=INF;
F(i,,n){
c[i]=i; a[i]=getint();
w[i]=len-(lower_bound(b+,b+len+,H-a[i])-b-);
}
sort(c+,c+n+,cmp);
F(i,,n) a[c[i]]=i;
F(i,,n*) t[i].min=INF;
F(i,,len){
ql=a[i]+; qr=n;
modify(,,n,-);
update(,,n,i,);
} #ifdef debug
F(i,,n) printf("%d %d\n",a[i],w[i]);
out(,,n);puts("");
#endif
int ans=t[].min>=;
F(i,len+,n){
ql=a[i-len]+; qr=n;
update(,,n,i-len,);
modify(,,n,); ql=a[i]+; qr=n;
update(,,n,i,);
modify(,,n,-);
if (t[].min>=) ans++;
#ifdef debug
printf("%d\n",i);
out(,,n);puts("");
#endif
}
printf("%d\n",ans);
return ;
}
【CodeForces】【338E】Optimize!的更多相关文章
- 【Codeforces #312 div2 A】Lala Land and Apple Trees
# [Codeforces #312 div2 A]Lala Land and Apple Trees 首先,此题的大意是在一条坐标轴上,有\(n\)个点,每个点的权值为\(a_{i}\),第一次从原 ...
- 【Codeforces Round #438 C】 Qualification Rounds
[链接]h在这里写链接 [题意] 给你n个问题,每个人都知道一些问题. 然后让你选择一些问题,使得每个人知道的问题的数量,不超过这些问题的数量的一半. [题解] 想法题. 只要有两个问题. 这两个问题 ...
- 【Codeforces Round #438 B】Race Against Time
[链接]h在这里写链接 [题意] 时针.分钟.秒针走不过去. 问你从t1时刻能不能走到t2时刻 [题解] 看看时针.分钟.秒针的影响就好. 看看是不是在整时的位置就好. 然后看看影响到x不能到y; 然 ...
- 【Codeforces Round #438 A】Bark to Unlock
[链接]h在这里写链接 [题意] 在这里写题意 [题解] 枚举它是在连接处,还是就是整个字符串就好. [错的次数] 0 [反思] 在这了写反思 [代码] #include <bits/stdc+ ...
- 【codeforces 718 C&D】C. Sasha and Array&D. Andrew and Chemistry
C. Sasha and Array 题目大意&题目链接: http://codeforces.com/problemset/problem/718/C 长度为n的正整数数列,有m次操作,$o ...
- 【Codeforces 321E / BZOJ 5311】【DP凸优化】【单调队列】贞鱼
目录 题意: 输入格式 输出格式 思路: DP凸优化的部分 单调队列转移的部分 坑点 代码 题意: 有n条超级大佬贞鱼站成一行,现在你需要使用恰好k辆车把它们全都运走.要求每辆车上的贞鱼在序列中都是连 ...
- 【codeforces contest 1119 F】Niyaz and Small Degrees
题目 描述 \(n\) 个点的树,每条边有一个边权: 对于一个 \(X\) ,求删去一些边后使得每个点的度数 \(d_i\) 均不超过 \(X\) 的最小代价: 你需要依次输出 \(X=0 \to n ...
- 【codeforces #282(div 1)】AB题解
A. Treasure time limit per test 2 seconds memory limit per test 256 megabytes input standard input o ...
- 【codeforces 415D】Mashmokh and ACM(普通dp)
[codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ...
- 【搜索】【并查集】Codeforces 691D Swaps in Permutation
题目链接: http://codeforces.com/problemset/problem/691/D 题目大意: 给一个1到N的排列,M个操作(1<=N,M<=106),每个操作可以交 ...
随机推荐
- [leetcode]_Valid Parentheses
题目:判断给定字符串中的括号是否合法.题目中涉及三种符号'(' + ')' , '[' + ']' , '{' + '}'. 思路:利用stack来存储符号. 注意申请char型stack是: Sta ...
- [leetcode]_Roman to Integer
题目:给定一个罗马数字串,转换为一个整数. 一开始没理解,以为是string to int.后来理解:罗马数字与阿拉伯数字的映射关系,见下图: 至此,题目的意思才掌握明白,用程序模拟这张表. 无可置否 ...
- VS2008无法切换到视图设计器
编写人:CC阿爸 2014-2-17 近来用于干活的笔记本电脑实在太慢了,在领导的安排下,有幸更换了一台配置好的电脑.经过一天的努力,所有之前的开发软件都安装完成了.并且OS从xp升级到win7.SQ ...
- sql server备份还原数据时的问题记录
1.关于“因为数据库正在使用,所以无法获得对数据库的独占访问权”的最终解决方案 关键SQL语句: ALTER DATABASE [datebase] SET OFFLINE WITH ROLLBACK ...
- rails中ActionController::InvalidAuthenticityToken解决办法
Ror代码 class FooController < ApplicationController protect_from_forgery :except => :index # you ...
- oh-my-zsh配置你的zsh提高shell逼格终极选择
抱歉,这篇博文推迟发布了,人都是有惰性的...看在这个牛逼闪闪的标题就原谅我吧! 为何这篇文章要归类到 mac 下? 第一个问题,稍后我们说明下. zsh是个什么东东? 第二个问题... 你应该稍微接 ...
- 黑客群体的露面说明互联网公司开始回馈IT行业了,
揭开中国黑客群体的神秘面纱 年薪数百万 2015-04-26 09:59:45 15259 次阅读 14 次推荐 稿源:经济观察报 33 条评论 在网络世界有专属的代号,那里才是他们最习惯的“世界 ...
- EF 随机排序
/// <summary> /// 数据上下文扩展 /// </summary> public partial class dbDataContext : IUnitOfWor ...
- Ubuntu 修改用户密码与启动root账号
passwd sban 修改当前帐号 sudo passwd root 修改root帐号 修改/etc/ssh/sshd_config,改: PermitRootLogin without-passw ...
- java 版本安装
系统:Ubuntu 10.04 JDK:jdk-6u20-linux-i586.bin 当然,我已经在sun的官方网站上下载好了必要的jdk,由于是在linux下安装,跟平时习惯的windows有所不 ...