浅谈主席树:https://www.cnblogs.com/AKMer/p/9956734.html

题目传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=1926

这题应该算是两题……首先贪心的想,我们肯定是尽量选厚的书。对于前\(50\)%的数据,我们可以统计大于等于\(k\)的数字的二维前缀和与书的本数,然后二分\(k\),直接\(O(1)\)计算厚度总和可不可以大于\(h\),记得,如果对于某个\(k\),如果这一个子矩阵里的高度总和大于\(h\),我们还要试着去掉厚度为\(k\)的书,让厚度总和尽可能逼近\(h\)才行。因为二分具有单调性,\(k\)满足而\(k+1\)不满足,那么你能去掉的厚度为\(k\)的本数肯定不会大于真实的\(k\)的本数。

对于后\(50\)%的数据,因为书架从矩阵退化成了数列,我们可以用主席树维护。我们在值域上建主席树,\(rt[i]\)表示第\(i\)个版本的主席树,也就是\(1\)~\(i\)号书全部插入主席树之后的主席树。对于一个询问[\(l,r\)],我们先看右儿子的总厚度是否大于\(h\),是的话就往右儿子走,否则使\(h\)减去右儿子的总厚度,到左儿子里去找剩下的\(h\)。当你确定到某一本厚度的时候,像二分那样,只返回要用的最少的本数而不是全部都返回。

时间复杂度:\(O(n^2p+mlogp)\)---前\(50\)%,\(O((n+m)logn)\)---后\(50\)%

空间复杂度:\(O(n^2p)\)---前\(50\)%,\(O(nlogn)\)---后\(50\)%

代码如下:

#include <cstdio>
using namespace std; const int maxn=5e5+5; int n,m,q,x1,x2;
int p1[205][205];
int p2[maxn],rt[maxn];
int sum[205][205][1005],cnt[205][205][1005]; int read() {
int x=0,f=1;char ch=getchar();
for(;ch<'0'||ch>'9';ch=getchar())if(ch=='-')f=-1;
for(;ch>='0'&&ch<='9';ch=getchar())x=x*10+ch-'0';
return x*f;
} void init() {
n=read(),m=read(),q=read();
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
if(n!=1)p1[i][j]=read();
else p2[j]=read();
} int calc(int (*a)[205][1005],int x1,int y1,int x2,int y2,int k) {
return a[x2][y2][k]-a[x1-1][y2][k]-a[x2][y1-1][k]+a[x1-1][y1-1][k];
} void solve1() {
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
for(int k=0;k<=1000;k++) {
sum[i][j][k]=sum[i][j-1][k]+sum[i-1][j][k]-sum[i-1][j-1][k];
cnt[i][j][k]=cnt[i][j-1][k]+cnt[i-1][j][k]-cnt[i-1][j-1][k];
if(p1[i][j]>=k) sum[i][j][k]+=p1[i][j],cnt[i][j][k]++;
}
for(int i=1;i<=q;i++) {
int x1=read(),y1=read(),x2=read(),y2=read(),h=read();
int l=0,r=1000,ans=-1;
while(l<r) {
int mid=(l+r+1)>>1;
int tmp=calc(sum,x1,y1,x2,y2,mid);
if(tmp<h)r=mid-1;
else {
l=mid,ans=calc(cnt,x1,y1,x2,y2,mid);
ans-=(tmp-h)/mid;//直接减,不要虚
}
}
if(ans==-1)puts("Poor QLW");
else printf("%d\n",ans);
}
} struct tree_node {
int cnt,sum,ls,rs;
}; struct chairman_tree {
int tot;
tree_node tree[maxn*20]; void ins(int lst,int &now,int l,int r,int pos) {
now=++tot;tree[now]=tree[lst];
tree[now].cnt++,tree[now].sum+=pos;
if(l==r)return;
int mid=(l+r)>>1;
if(pos<=mid)ins(tree[lst].ls,tree[now].ls,l,mid,pos);
else ins(tree[lst].rs,tree[now].rs,mid+1,r,pos);
} int query(int L,int R,int l,int r,int limit) {
if(tree[R].sum-tree[L].sum<limit)return -1;
if(l==r) {
int tmp=tree[R].cnt-tree[L].cnt;
int fake=tree[R].sum-tree[L].sum;
return tmp-(fake-limit)/l;//本数减去可以去掉的数量
}
int mid=(l+r)>>1,tmp=tree[tree[R].rs].sum-tree[tree[L].rs].sum;
int fake=tree[tree[R].rs].cnt-tree[tree[L].rs].cnt;
if(tmp>=limit)return query(tree[L].rs,tree[R].rs,mid+1,r,limit);
else return query(tree[L].ls,tree[R].ls,l,mid,limit-tmp)+fake;
return 0;
}
}T; void solve2() {
for(int i=1;i<=m;i++)
T.ins(rt[i-1],rt[i],1,1000,p2[i]);
for(int i=1;i<=q;i++) {
x1=read();int l=read();x2=read();int r=read(),h=read();
int ans=T.query(rt[l-1],rt[r],1,1000,h);
if(ans==-1)puts("Poor QLW");
else printf("%d\n",ans);
}
} int main() {
init();
if(n!=1)solve1();
else solve2();
return 0;
}

BZOJ1926:[SDOI2010]粟粟的书架的更多相关文章

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

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

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

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

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

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

  4. BZOJ1926[Sdoi2010]粟粟的书架——二分答案+主席树

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

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

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

  6. 【BZOJ1926】【SDOI2010】粟粟的书架 [主席树]

    粟粟的书架 Time Limit: 30 Sec  Memory Limit: 552 MB[Submit][Status][Discuss] Description 幸福幼儿园 B29 班的粟粟是一 ...

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

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

  8. 【BZOJ-1926】粟粟的书架 二分 + 前缀和 + 主席树

    1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Sec  Memory Limit: 552 MBSubmit: 616  Solved: 238[Submit][Statu ...

  9. 【BZOJ1926】粟粟的书架(主席树,前缀和)

    [BZOJ1926]粟粟的书架(主席树,前缀和) 题面 Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Co ...

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

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

随机推荐

  1. (webstorm的css编写插件)Emmet:HTML/CSS代码快速编写神器

    Emmet的前身是大名鼎鼎的Zen coding,如果你从事Web前端开发的话,对该插件一定不会陌生.它使用仿CSS选择器的语法来生成代码,大大提高了HTML/CSS代码编写的速度,比如下面的演示: ...

  2. CPU调度算法

    批处理系统中的调度算法: *需要考虑的因素: 1. 吞吐量 2. cpu利用率 3. 周转时间 4. 公平性* 1.先来先服务: FCFS: 优点:实现简单 缺点:可能造成周转时间长 2.最短作业优先 ...

  3. VS中单元测试用法

    using System; using Microsoft.VisualStudio.TestTools.UnitTesting; namespace UnitTestProject1 { [Test ...

  4. FTP匿名登录或弱口令漏洞及服务加固

    漏洞描述 FTP 弱口令或匿名登录漏洞,一般指使用 FTP 的用户启用了匿名登录功能,或系统口令的长度太短.复杂度不够.仅包含数字.或仅包含字母等,容易被黑客攻击,发生恶意文件上传或更严重的入侵行为. ...

  5. Excel COM组件使用的注意事项和一些权限问题(转载)

    1.实例化Excel的COM组件的时候,不要直接调用类,要用Microsoft提供的接口 原来的写法:Excel.ApplicationClass excelApp = new Excel.Appli ...

  6. AI生万物,新世界的大门已敞开

    四月是万物复苏的时节,一年一度的GMIC全球移动互联网大会也在这个时间如期而至,在4月26日-28日的会议期间,有超过三百位行业专家进行了精彩的演讲,更有数万名现场观众感受到思维碰撞迸发出的火花. 作 ...

  7. 删除rabbitmq的队列和队列中的数据

      访问http://{rabbitmq安装IP}:15672,帐号guest,密码guest(也可以使用自己创建的帐号). 登录后访问http://{rabbitmq安装IP}:15672/#/qu ...

  8. java 面试总结

    1.static变量与实体变量的差别? static是静态变量,static能够通过类名直接訪问 内存方面的不同:static在定义的时候jvm就会分配空间, 而实体变量仅仅有在创建对象的时候才会去分 ...

  9. ASP.NET动态网站制作(1)--html

    前言:正式上课的第一课,讲的是前端部分的最基础内容:html. 前端:html,css,js 数据库:sql server 动态部分:.net,c#... IIS(Internet Informati ...

  10. 利用Docker Compose快速搭建本地测试环境

    前言 Compose是一个定义和运行多个Docker应用的工具,用一个YAML(dockder-compose.yml)文件就能配置我们的应用.然后用一个简单命令就能启动所有的服务.Compose编排 ...