BZOJ 1828
program bzoj1828;
const maxn=;
check=; type node=record
l,r,s,a:longint;
end; var t:array [..maxn*] of node;
a,b,c:array [..maxn] of longint;
n,m,i,ans,mini:longint; procedure swap(var x,y:longint);
begin
x:=x xor y;
y:=x xor y;
x:=x xor y;
end; procedure qsort(l,r:longint);
var i,j,mia,mib:longint;
begin
i:=l; j:=r;
mia:=a[(l+r) shr ]; mib:=b[(l+r) shr ];
while i<=j do
begin
while (b[i]<mib) or (b[i]=mib) and (a[i]<mia) do inc(i);
while (b[j]>mib) or (b[j]=mib) and (a[j]>mia) do dec(j);
if i<=j then
begin
swap(a[i],a[j]);
swap(b[i],b[j]);
inc(i);
dec(j);
end;
end;
if i<r then qsort(i,r);
if j>l then qsort(l,j);
end; function min(x,y:longint):longint;
begin
if x<y then exit(x)
else exit(y);
end; procedure build(l,r,i:longint);
var mid:longint;
begin
t[i].l:=l;
t[i].r:=r;
if l=r then
begin
t[i].s:=c[l];
exit;
end;
mid:=(l+r)>>;
build(l,mid,i<<);
build(mid+,r,i<<+);
t[i].s:=min(t[i<<].s,t[i<<+].s);
end; procedure pass(i,add:longint);
var lch,rch:longint;
begin
lch:=i shl ;
rch:=lch+;
inc(t[lch].s,add);
inc(t[rch].s,add);
inc(t[lch].a,add);
inc(t[rch].a,add);
t[i].a:=;
end; procedure change(l,r,add,i:longint);
var mid:longint;
begin
if (t[i].l=l)and(t[i].r=r) then
begin
inc(t[i].s,add);
inc(t[i].a,add);
exit;
end;
if t[i].a<> then pass(i,t[i].a);
mid:=(t[i].l+t[i].r)>>;
if r<=mid then change(l,r,add,i<<)
else
if l>mid then change(l,r,add,i<<+)
else
begin
change(l,mid,add,i<<);
change(mid+,r,add,i<<+);
end;
t[i].s:=min(t[i<<].s,t[i<<+].s);
end; function getans(l,r,i:longint):longint;
var mid,ans1,ans2:longint;
begin
if t[i].a<> then pass(i,t[i].a);
if (t[i].l=l)and(t[i].r=r) then exit(t[i].s);
ans1:=check;
ans2:=check;
mid:=(t[i].l+t[i].r)>>;
if r<=mid then ans1:=getans(l,r,i<<)
else
if l>mid then ans2:=getans(l,r,i<<+)
else
begin
ans1:=getans(l,mid,i<<);
ans2:=getans(mid+,r,i<<+);
end;
exit(min(ans1,ans2));
end; begin
read(n,m);
for i:= to n do read(c[i]);
build(,n,);
for i:= to m do read(a[i],b[i]);
sort(,m);
for i:= to m do
begin
mini:=getans(a[i],b[i],);
if mini> then
begin
inc(ans);
change(a[i],b[i],-,);
end;
end;
writeln(ans);
end.
BZOJ 1828的更多相关文章
- BZOJ 1828 [Usaco2010 Mar]balloc 农场分配(贪心+线段树)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1828 [题目大意] 现在有一些线段[l,r]的需求需要满足,i位置最多允许a[i]条线 ...
- BZOJ 1828: [Usaco2010 Mar]balloc 农场分配
Description Input 第1行:两个用空格隔开的整数:N和M * 第2行到N+1行:第i+1行表示一个整数C_i * 第N+2到N+M+1行: 第i+N+1行表示2个整数 A_i和B_i ...
- bzoj 1828: [Usaco2010 Mar]balloc 农场分配【贪心+线段树】
长得挺唬人的贪心,按照右端点排序,用最小值线段树的询问判断当前牛是否能放进去,能的话更新线段树,ans++ 来自https://www.cnblogs.com/rausen/p/4529245.htm ...
- bzoj usaco 金组水题题解(1)
UPD:我真不是想骗访问量TAT..一开始没注意总长度写着写着网页崩了王仓(其实中午的时候就时常开始卡了= =)....损失了2h(幸好长一点的都单独开了一篇)....吓得赶紧分成两坨....TAT. ...
- USACO 刷题记录bzoj
bzoj 1606: [Usaco2008 Dec]Hay For Sale 购买干草——背包 #include<cstdio> #include<cstring> #incl ...
- 【BZOJ】1828: [Usaco2010 Mar]balloc 农场分配(经典贪心)
[算法]贪心+线段树 [题意]给定n个数字ci,m个区间[a,b](1<=a,b<=10^5),每个位置最多被ci个区间覆盖,求最多选择多少区间. 附加退化问题:全部ci=1,即求最多的不 ...
- 【BZOJ】1707: [Usaco2007 Nov]tanning分配防晒霜
[算法]贪心扫描线(+堆) [题意]给定n头牛有区间[a,b],m个防晒霜值为ai,每个可以使用bi次,每次可以使包含它的区间涂到防晒霜,问最多被涂牛数. [题解] 参考:[bzoj1707]: [U ...
- BZOJ 2127: happiness [最小割]
2127: happiness Time Limit: 51 Sec Memory Limit: 259 MBSubmit: 1815 Solved: 878[Submit][Status][Di ...
- BZOJ 3275: Number
3275: Number Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 874 Solved: 371[Submit][Status][Discus ...
随机推荐
- 让你提前知道软件开发(24):C语言和主要特征的发展史
文章1部分 再了解C语言 C语言的发展历史和主要特点 作为一门众所周知的计算机编程语言,C语言是谁发明的呢?它是怎样演进的?它有何特点?究竟有多少人在使用它? 1. C语言之父 C语言是1972年由美 ...
- CSS文字样式
font-family:通常文章的正文使用的是易读性较强的serif字体,用户长时间阅读下不easy疲劳.而标题和表格则採用较醒目的sans-serif字体.Web设计及浏览器设置中也推荐遵循此原则. ...
- python 类属性、对象属性
类的普通属性: dir(Myclass), 返回一个key列表: Myclass.__dir__,返回一个字典: 1.类的数据属性: 2.类的方法: 类的特殊属性: 1.Myclass.__name_ ...
- WPF 实现的等待效果界面
这个界面的效果是从WinForm 转变过来,可以实现等待的效果,操作完成以后就自动关掉. 效果图如下 有一个动态的手机等待效果的样式,中间的文字可以自己定义,提供了方法可以修改中间"正在加载 ...
- ExtJS002Window创建
Ext.onReady(function () { Ext.create('Ext.window.Window', { title: 'window', width: 400, height: 300 ...
- BZOJAC400题留念
BZOJAC400题了...
- 驱动之路四------adc驱动(input设备)
开发板:smdk6410 开发环境:Linux 突然想起一点,写这些驱动,内核需要配成支持抢占才行. 前面的博客已经将其它的基本知识都解释了,这里也就不过多的阐述了,咱就直接写代码吧 这次写的是adc ...
- codeforces 375D . Tree and Queries 启发式合并 || dfs序+莫队
题目链接 一个n个节点的树, 每一个节点有一个颜色, 1是根节点. m个询问, 每个询问给出u, k. 输出u的子树中出现次数大于等于k的颜色的数量. 启发式合并, 先将输入读进来, 然后dfs完一个 ...
- socket 通信 入门3 android 客户端 C# 服务端
这是一个android端操控服务器的例子 就是发送简单指令到服务器 然后服务器响应什么的... 当然这里是未完成的 只是简单展示一下大致思路 首先连接建立起来后 服务端给客户端一条信息 告诉 ...
- NET Core Docker部署
NET Core Docker部署 前言 在前面文章中,介绍了 ASP.NET Core在 macOS,Linux 上基于Nginx和Jexus的发布和部署,本篇文章主要是如何在Docker容器中运行 ...