\[Preface
\]

看到这题洛谷标签有 主席树 ,还以为是什么二维主席树的玄学做法(雾

\[Description
\]

给出一个 \(R×C\) 的矩阵。

一共 \(m\) 次询问,每次询问给出一个五元组 \((x1,y1,x2,y2,h)\) 。

求:在矩阵 \((x1,y1,x2,y2)\) 里至少取多少个数,它们的和大于等于 \(h\)

无解输出 Poor QLW

\[Solution
\]

显然是贪心地取数,数取的越大,就可以越早使和大于等于 \(h\) 。

因此我们都考虑优先选择大的数,然后一步一步往小的数考虑。

所以我们可以把 " 矩阵内大于等于 \(k\) 的数 " 的和以及个数求出来,然后去二分取数的最小值,把最优性问题转化成一个判定性问题。

\(~\)

注意到:

对于50%的数据,满足R, C≤200,M≤200,000;

另有50%的数据,满足R=1,C≤500,000,M≤20,000;

\(~\)

对于 \(type1\) ,可以直接用 \(O(1000RC)\) 的时间预处理(二维前缀和)。

\(~\)

对于 \(type2\) ,发现 \(O(1000RC)\) 的时间预处理会 \(T\) 飞。

观察到 \(R=1\) ,此时实质上这个矩阵是一个序列,解决 " 区间内大于等于 \(k\) 的数 " 的和以及个数正是主席树擅长的,用主席树维护一下即可。

\[Code
\]

#include<cstdio>

#define RI register int

using namespace std;

inline int read()
{
int x=0,f=1;char s=getchar();
while(s<'0'||s>'9'){if(s=='-')f=-f;s=getchar();}
while(s>='0'&&s<='9'){x=x*10+s-'0';s=getchar();}
return x*f;
} const int N1=210,N2=500100,MLOGN=10001000; const int MaxV=1000; int n,m,Q; int val[N1][N1];
int sum[N1][N1][MaxV+100],cnt[N1][N1][MaxV+100]; int GetSum(int x1,int y1,int x2,int y2,int k)
{
return sum[x2][y2][k]-sum[x1-1][y2][k]-sum[x2][y1-1][k]+sum[x1-1][y1-1][k];
} int GetCnt(int x1,int y1,int x2,int y2,int k)
{
return cnt[x2][y2][k]-cnt[x1-1][y2][k]-cnt[x2][y1-1][k]+cnt[x1-1][y1-1][k];
} void Work1()
{
for(RI i=1;i<=n;i++)
for(RI j=1;j<=m;j++)
val[i][j]=read(); for(RI k=1;k<=MaxV;k++)
for(RI i=1;i<=n;i++)
for(RI j=1;j<=m;j++)
{
sum[i][j][k]=sum[i-1][j][k]+sum[i][j-1][k]-sum[i-1][j-1][k]+(val[i][j]>=k?val[i][j]:0);
cnt[i][j][k]=cnt[i-1][j][k]+cnt[i][j-1][k]-cnt[i-1][j-1][k]+(val[i][j]>=k?1:0);
} while(Q--)
{
int x1=read(),y1=read(),x2=read(),y2=read(),h=read(); if(GetSum(x1,y1,x2,y2,1)<h)
{
puts("Poor QLW");
continue;
} int l=1,r=MaxV;
while(l<r)
{
int mid=(l+r+1)/2;
if(GetSum(x1,y1,x2,y2,mid)<h)
r=mid-1;
else
l=mid;
} printf("%d\n",GetCnt(x1,y1,x2,y2,l)-(GetSum(x1,y1,x2,y2,l)-h)/l);
}
} int seq[N2]; int tot,root[N2];
struct SegmentTree{
int lc,rc;
int cnt;
int sum;
}t[MLOGN]; int New()
{
tot++;
t[tot].lc=t[tot].rc=t[tot].cnt=t[tot].sum=0;
return tot;
} void insert(int &p,int now,int l,int r,int delta,int val1,int val2)
{
p=New();
t[p]=t[now];
t[p].cnt+=val1;
t[p].sum+=val2;
if(l==r)return;
int mid=(l+r)/2;
if(delta<=mid)
insert(t[p].lc,t[now].lc,l,mid,delta,val1,val2);
else
insert(t[p].rc,t[now].rc,mid+1,r,delta,val1,val2);
} int ask(int p,int q,int l,int r,int h)
{
if(l==r)return (h-1)/l+1;
int mid=(l+r)/2;
int rcnt=t[t[q].rc].cnt-t[t[p].rc].cnt,
rsum=t[t[q].rc].sum-t[t[p].rc].sum;
if(h<=rsum)
return ask(t[p].rc,t[q].rc,mid+1,r,h);
else
return ask(t[p].lc,t[q].lc,l,mid,h-rsum)+rcnt;
} void Work2()
{
n=m;
for(RI i=1;i<=n;i++)
seq[i]=read(); for(RI i=1;i<=n;i++)
insert(root[i],root[i-1],1,MaxV,seq[i],1,seq[i]); while(Q--)
{
int l,r,h;
read(),l=read(),read(),r=read(),h=read(); if(t[root[r]].sum-t[root[l-1]].sum<h)
{
puts("Poor QLW");
continue;
} printf("%d\n",ask(root[l-1],root[r],1,MaxV,h));
}
} int main()
{
n=read(),m=read(),Q=read(); if(n>1)
Work1();
else
Work2(); return 0;
}

\[Thanks \ for \ watching
\]

题解 SDOI2010 【栗栗的书架】的更多相关文章

  1. bzoj1926[Sdoi2010]粟粟的书架 二分 主席树

    1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Sec  Memory Limit: 552 MBSubmit: 1064  Solved: 421[Submit][Stat ...

  2. bzoj 1926: [Sdoi2010]粟粟的书架 (主席树+二分)

    链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1926 题面; 1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Se ...

  3. Bzoj 1926: [Sdoi2010]粟粟的书架(二分答案+乱搞+主席树)

    1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Sec Memory Limit: 552 MB Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱 ...

  4. [SDOI2010]粟粟的书架 [主席树]

    [SDOI2010]粟粟的书架 考虑暴力怎么做 显然是提取出来 (x2-x1+1)*(y2-y1+1) 个数字拿出来 然后从大到小排序 然后就可以按次取数了- 然而接下来看数据范围 \(50\%\ r ...

  5. BZOJ1926:[SDOI2010]粟粟的书架——题解

    http://www.lydsy.com/JudgeOnline/problem.php?id=1926 https://www.luogu.org/problemnew/show/P2468 幸福幼 ...

  6. BZOJ1926 [Sdoi2010]粟粟的书架 【主席树 + 二分 + 前缀和】

    题目 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Co rmen 的文章.粟粟家中有一个 R行C 列的巨型书架,书架的每一个位置都 ...

  7. [bzoj1926][Sdoi2010]粟粟的书架_二分_主席树

    粟粟的书架 bzoj-1926 Sdoi-2010 题目大意:题目链接 注释:略 想法:分成两个题 前面的我们可以二分,直接二分出来检验即可. 对于R=1的,相当一个数列,我们在上面建立主席树. 然后 ...

  8. BZOJ 1926: [Sdoi2010]粟粟的书架(主席树,二分答案)

    BZOJ 1926: [Sdoi2010]粟粟的书架(主席树,二分答案) 题意 : 给你一个长为\(R\)宽为\(C\)的矩阵,第\(i\)行\(j\)列的数为\(P_{i,j}\). 有\(m\)次 ...

  9. [BZOJ1926][SDOI2010]粟粟的书架

    BZOJ Luogu Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Cormen 的文章.粟粟家中有一个 R ...

随机推荐

  1. spring boot集成spring-boot-starter-mail邮件功能

    前情提要 以目前IT系统功能来看,邮件功能是非常重要的一个功能.例如:找回密码.邮箱验证,邮件动态码.忘记密码,邮件营销等,都需要用到邮件功能.结合当下最流行的spring boot微服务,推出了sp ...

  2. 现状、趋势如何?——《2019 年度 SaaS 行业【企业愿景】展望 · 总结篇》

    SaaS 行业产业地图和行业规模 看完SaaS的概念介绍,聪明的小伙伴们应该都理解了SaaS到底是个什么东西,但TOB的应用一般会离生活比较远,这里直接上产业地图,让大家对常见的SaaS产品有一个直观 ...

  3. kubespy 用bash实现的k8s动态调试工具

    原文位于 https://github.com/huazhihao/kubespy/blob/master/implement-a-k8s-debug-plugin-in-bash.md 背景 Kub ...

  4. fastjson使用详解

    目录 二.fastjson使用 三.fastjson 常用 API 四.fastjson使用演示 测试类准备 1.java类转换为json字符串 2.json字符串转为java类 五.fastjson ...

  5. 牛客暑期ACM多校 第七场

    链接:https://www.nowcoder.com/acm/contest/145/C来源:牛客网 C .题目描述 A binary string s of length N = 2n is gi ...

  6. hdu6638 线段树求最大子段和

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6638 Problem Description There are n pirate chests bu ...

  7. idea 忽略不需要提交的文件

    1.打开git bash界面,进入到某个项目的根目录,执行下面命令 touch .gitignore 此时,再该项目的根目录里,会创建.gitignore文本,打开该文本,编辑需要忽略的文件(编辑规则 ...

  8. 如何编写Robot Framework测试用例1---(基本格式篇)

    引子 我们使用符合Robot Framework规范的一种表格语法来编写测试用例.用例一般会是下面这个样子 这样的表格存储到一个文件中,就是一组测试用例.RF支持多种格式,如HTML,TSV,纯文本等 ...

  9. 全网最详细!Centos7.X 搭建Grafana+Jmeter+Influxdb 性能实时监控平台

    背景 日常工作中,经常会用到Jmeter去压测,毕竟LR还要钱(@¥&*...),而最常用的接口压力测试,我们都是通过聚合报告去查看压测结果的,然鹅聚合报告的真的是丑到家了,作为程序猿这当然不 ...

  10. sqlalchemy 单表增删改查

    1.连接数据库,并创建session from sqlalchemy.orm import sessionmaker from sqlalchemy import create_engine engi ...