【BZOJ-1926】粟粟的书架 二分 + 前缀和 + 主席树
1926: [Sdoi2010]粟粟的书架
Time Limit: 30 Sec Memory Limit: 552 MB
Submit:
616 Solved: 238
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
14 15 9 26 53
58 9 7 9
32
38 46 26 43 38
32 7 9 50 28
8 41 9 7 17
1 2 5 3 139
3 1 5
5 399
3 3 4 5 91
4 1 4 1 33
1 3 5 4 185
3 3 4 3 23
3 1 3 3
108
Sample Output
15
2
Poor QLW
9
1
3
HINT
对于 10%的数据,满足 R, C≤10;
Source
Solution
其实是按两道题来做的
对于R>1的情况,考虑利用 前缀和+二分 暴力的去处理
维护两个前缀和 sum[i][j][k]表示>=k的数的和,num[i][j][k]表示>=k的数的个数
二分的加加减减搞搞就可以
对于R=1的情况,考虑用 主席树 去维护序列
同样二分的算算就可以得到答案
内存爆炸,感觉带上正常的内存限制,正解应该是 二维莫队算法 去处理前缀和吧
Code
#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<cstring>
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 R,C,M;
#define maxn 500010
int Sum[maxn*],Num[maxn*],ll[maxn*],rr[maxn*],root[maxn<<],sz;
int sum[][][],num[][][],p[][];
void Insert(int l,int r,int &now,int fat,int val)
{
now=++sz; Sum[now]=Sum[fat]+val; Num[now]=Num[fat]+;
if (l==r) return;
ll[now]=ll[fat],rr[now]=rr[fat];
int mid=(l+r)>>;
if (val<=mid) Insert(l,mid,ll[now],ll[fat],val);
else Insert(mid+,r,rr[now],rr[fat],val);
}
int Query(int l,int r,int L,int R,int kth)
{
if (Sum[root[R]]-Sum[root[L-]]<kth) return -;
L=root[L-]; R=root[R];
int re=;
while (l<r)
{
int mid=(l+r)>>,tmp=Sum[rr[R]]-Sum[rr[L]];
if (tmp<kth) {re+=Num[rr[R]]-Num[rr[L]]; kth-=tmp; r=mid; L=ll[L]; R=ll[R];}
else {l=mid+; L=rr[L]; R=rr[R];}
}
re+=(kth+l-)/l;
return re;
}
void Part1()
{
for (int i=; i<=C; i++) Insert(,,root[i],root[i-],read());
while (M--)
{
int x1=read(),y1=read(),x2=read(),y2=read(),h=read();
int ans=Query(,,y1,y2,h);
if (ans==-) {puts("Poor QLW"); continue;}
printf("%d\n",ans);
}
}
int GetSum(int x1,int y1,int x2,int y2,int k) {return sum[x1-][y1-][k]+sum[x2][y2][k]-sum[x1-][y2][k]-sum[x2][y1-][k];}
int GetNum(int x1,int y1,int x2,int y2,int k) {return num[x1-][y1-][k]+num[x2][y2][k]-num[x1-][y2][k]-num[x2][y1-][k];}
void Part2()
{
int maxx=;
for (int i=; i<=R; i++)
for (int j=; j<=C; j++)
p[i][j]=read(),maxx=max(maxx,p[i][j]);
for (int i=; i<=R; i++)
for (int j=; j<=C; j++)
for (int k=; k<=maxx; k++)
num[i][j][k]=num[i-][j][k]+num[i][j-][k]-num[i-][j-][k]+(p[i][j]>=k?:),
sum[i][j][k]=sum[i-][j][k]+sum[i][j-][k]-sum[i-][j-][k]+(p[i][j]>=k?p[i][j]:);
while (M--)
{
int x1=read(),y1=read(),x2=read(),y2=read(),h=read();
int l=,r=maxx+,k=-;
while (l+<r)
{
int mid=(l+r)>>;
if (GetSum(x1,y1,x2,y2,mid)>=h) l=mid,k=mid; else r=mid;
}
if (k==-) {puts("Poor QLW"); continue;}
printf("%d\n",GetNum(x1,y1,x2,y2,k)-(GetSum(x1,y1,x2,y2,k)-h)/k);
}
}
int main()
{
R=read(),C=read(),M=read();
if (R==) Part1(); else Part2();
return ;
}
本来想先到CodeVS上试水,发现全都MLE了...无奈BZOJ交,直接A了..而且跑进了前10.愉快
【BZOJ-1926】粟粟的书架 二分 + 前缀和 + 主席树的更多相关文章
- BZOJ 3439: Kpm的MC密码 (trie+dfs序主席树)
题意 略 分析 把串倒过来插进trietrietrie上, 那么一个串的kpmkpmkpm串就是这个串在trietrietrie上对应的结点的子树下面的所有字符串. 那么像 BZOJ 3551/354 ...
- BZOJ.1926.[SDOI2010]粟粟的书架(前缀和 主席树 二分)
题目链接 题意: 在给定矩形区域内找出最少的数,满足和>=k.输出数的个数.两种数据范围. 0~50 注意到(真没注意到...)P[i,j]<=1000,我们可以利用前缀和预处理. num ...
- bzoj 1926: [Sdoi2010]粟粟的书架 (主席树+二分)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1926 题面; 1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Se ...
- Bzoj 1926: [Sdoi2010]粟粟的书架(二分答案+乱搞+主席树)
1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Sec Memory Limit: 552 MB Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱 ...
- BZOJ 1926: [Sdoi2010]粟粟的书架(主席树,二分答案)
BZOJ 1926: [Sdoi2010]粟粟的书架(主席树,二分答案) 题意 : 给你一个长为\(R\)宽为\(C\)的矩阵,第\(i\)行\(j\)列的数为\(P_{i,j}\). 有\(m\)次 ...
- 【刷题】BZOJ 1926 [Sdoi2010]粟粟的书架
Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Cormen 的文章.粟粟家中有一个 R行C 列的巨型书架,书 ...
- 洛谷P2468 [SDOI2010]粟粟的书架(二分答案 前缀和 主席树)
题意 题目链接 给出一个矩形,每个点都有一些值,每次询问一个子矩阵最少需要拿几个数才能构成给出的值 Sol 这题是真坑啊.. 首先出题人强行把两个题拼到了一起, 对于前$50 \%$的数据,考虑二分答 ...
- BZOJ 4556 [Tjoi2016&Heoi2016]字符串 ——后缀数组 ST表 主席树 二分答案
Solution 1: 后缀数组暴力大法好 #include <map> #include <cmath> #include <queue> #include &l ...
- bzoj 2588 Spoj 10628. Count on a tree(主席树)
Description 给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v,k),你需要回答u xor lastans和v这两个节点间第K小的点权.其中lastans是上一个询问的答案,初始 ...
随机推荐
- javascript数组对象排序
javascript数组对象排序 JavaScript数组内置排序函数 javascript内置的sort函数是多种排序算法的集合 JavaScript实现多维数组.对象数组排序,其实用的就是原生的s ...
- 利用ThinkPHP自带的七牛云驱动上传文件到七牛云以及删除七牛云文件方法
一.准备工作 1.注册七牛云账号 2.选择对象储存->创建空间->设置为公开 3.在config配置文件中添加以下代码 'UPLOAD_FILE_QINIU' => array ( ...
- intellij idea 高级用法之:集成JIRA、UML类图插件、集成SSH、集成FTP、Database管理
之前写过一篇IntelliJ IDEA 13试用手记,idea还有很多高大上的功能,易用性几乎能与vs.net媲美,反正我自从改用idea后,再也没开过eclipse,今天来看几个高级功能: 一.与J ...
- TF400916错误修复办法
在使用TFS作为研发过程管理工具的时候,如果调整了工作项的状态信息,可能会出现下面的错误: 要解决此问题非常简单: 1.找一台安装了VS2015程序的环境.因为我们使用的是TFS2015,所以需要对应 ...
- RSA签名验签学习笔记
RSA私钥签名时要基于某个HASH算法,比如MD5或者SHA1等.之前我一直认为签名的过程是:先对明文做HASH计算,然后用私钥直接对HASH值加密.最近才发现不是那么简单,需要对HASH后的数据进行 ...
- linux的点滴积累
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #839496; background-color: rgba(1 ...
- apache 多端口配置和虚拟主机配置
1 打开httpd.conf文件 2 添加端口监听 (找到Lisen 80 在后面添加 Listen 端口号 如Listen 1112) port =>你的端口 project_name=> ...
- c++ iterator(迭代器)分类及其使用
前言: 以下的内容为我阅读c++沉思录18,19,20章的笔记以及自己的想法. 正文: 总所周知,c++的stl中提出了iterator的概念,这是C所没有的.在一般的使用中,iterator的行为很 ...
- Java 关键字static final使用总结
Static表示“全局”或者“静态”的意思,用来修饰成员变量和成员方法,也可以形成静态static代码块,被static修饰的成员变量和成员方法独立于该类的任何对象.也就是说,它不依赖类特定的实例,被 ...
- C++_STL
容器概念讲解 vector deque