P2468 [SDOI2010]粟粟的书架
二合一题....
前面 $50$ 分:
考虑取书显然优先取厚的,所以答案满足单调性
发现 $P_{i,j}$ 不大,所以考虑二分最小厚度 $mid$,把大于等于 $mid$ 的书取走
维护 $cnt[i][j][k]$ 表示位置 $i,j$ 为右下角一直到 $1,1$ 的矩形内厚度大于等于 $k$ 的书的数量
维护 $sum[i][j][k]$ 表示位置 $i,j$ 为右下角一直到 $1,1$ 的矩形内厚度大于等于 $k$ 的书的总厚度
然后就可以愉快地二分答案了,注意最后要特判一下厚度为 $ans$ 的书不完全取完的情况!
后面 $50$ 分:
因为只有一行,考虑用主席树维护每个区间的所有值,然后处理询问在主席树上走就好了
同样注意特判最后一种厚度的书不完全取完的情况
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
using namespace std;
typedef long long ll;
inline int read()
{
int x=,f=; char ch=getchar();
while(ch<''||ch>'') { if(ch=='-') f=-; ch=getchar(); }
while(ch>=''&&ch<='') { x=(x<<)+(x<<)+(ch^); ch=getchar(); }
return x*f;
}
const int N=,M=5e5+,INF=1e9+;
int n,m,Q; int cnt[N][N][],sum[N][N][];//sum是总和,cnt是数量
int xa,ya,xb,yb,H,mx;
inline int clac(int p) { return sum[xb][yb][p]-sum[xa-][yb][p]-sum[xb][ya-][p]+sum[xa-][ya-][p]; }//求一个矩形的sum
inline int CNT(int p) { return cnt[xb][yb][p]-cnt[xa-][yb][p]-cnt[xb][ya-][p]+cnt[xa-][ya-][p]; }//求一个矩形的cnt
inline int query()//二分答案
{
int res=-,l=,r=mx+,mid=l+r>>;
while(l<=r)
{
mid=l+r>>;
if(clac(mid)>=H) l=mid+,res=mid;
else r=mid-;
}
return res;
}
int bk[N][N];
void solve1()//前面50分
{
for(int i=;i<=n;i++)
for(int j=;j<=m;j++) bk[i][j]=read(),mx=max(mx,bk[i][j]);
for(int k=;k<=mx;k++)
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
{
sum[i][j][k]=sum[i-][j][k]+sum[i][j-][k]-sum[i-][j-][k]+(bk[i][j]>=k ? bk[i][j] : );
cnt[i][j][k]=cnt[i-][j][k]+cnt[i][j-][k]-cnt[i-][j-][k]+(bk[i][j]>=k ? : );
}
while(Q--)
{
xa=read(),ya=read(),xb=read(),yb=read(),H=read();
int t=query();
if(t==-) printf("Poor QLW\n");
else printf("%d\n", CNT(t) - (clac(t)-H)/t );//注意特判厚度为t的书不全取
}
} int t[M<<],sz[M<<],L[M<<],R[M<<],rt[M],tot;
int res,val;
inline void ins(int &o,int l,int r,int pre)
{
o=++tot; t[o]=t[pre]+val; sz[o]=sz[pre]+;
int mid=l+r>>;
if(l==r) return;
if(val<=mid) ins(L[o],l,mid,L[pre]),R[o]=R[pre];
else ins(R[o],mid+,r,R[pre]),L[o]=L[pre];
}
inline void query(int hea,int las,int l,int r)//在主席树上走
{
int mid=l+r>>;
if(l==r)
{
res+= (val/l+(val%l!=)) ;//注意特判
return;
}
if(t[R[las]]-t[R[hea]]<=val)//优先取大的
{
res+=sz[R[las]]-sz[R[hea]]; val-=t[R[las]]-t[R[hea]];
query(L[hea],L[las],l,mid);
}
else query(R[hea],R[las],mid+,r);
}
inline void solve2()//后50分
{
int l,r,a,b;
for(int i=;i<=m;i++) val=read(),ins(rt[i],,,rt[i-]);
while(Q--)
{
a=read(),l=read(),b=read(),r=read(),val=read();
if(t[rt[r]]-t[rt[l-]]<val) { printf("Poor QLW\n"); continue; }//特判
res=; query(rt[l-],rt[r],,);
printf("%d\n",res);
}
} int main()
{
n=read(),m=read(),Q=read();
if(n>) solve1();
else solve2();
return ;
}
P2468 [SDOI2010]粟粟的书架的更多相关文章
- bzoj1926[Sdoi2010]粟粟的书架 二分 主席树
1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Sec Memory Limit: 552 MBSubmit: 1064 Solved: 421[Submit][Stat ...
- bzoj 1926: [Sdoi2010]粟粟的书架 (主席树+二分)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1926 题面; 1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Se ...
- BZOJ1926:[SDOI2010]粟粟的书架——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=1926 https://www.luogu.org/problemnew/show/P2468 幸福幼 ...
- [bzoj1926][Sdoi2010]粟粟的书架_二分_主席树
粟粟的书架 bzoj-1926 Sdoi-2010 题目大意:题目链接 注释:略 想法:分成两个题 前面的我们可以二分,直接二分出来检验即可. 对于R=1的,相当一个数列,我们在上面建立主席树. 然后 ...
- Bzoj 1926: [Sdoi2010]粟粟的书架(二分答案+乱搞+主席树)
1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Sec Memory Limit: 552 MB Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱 ...
- [SDOI2010]粟粟的书架 [主席树]
[SDOI2010]粟粟的书架 考虑暴力怎么做 显然是提取出来 (x2-x1+1)*(y2-y1+1) 个数字拿出来 然后从大到小排序 然后就可以按次取数了- 然而接下来看数据范围 \(50\%\ r ...
- [BZOJ1926][SDOI2010]粟粟的书架
BZOJ Luogu Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Cormen 的文章.粟粟家中有一个 R ...
- BZOJ1926[Sdoi2010]粟粟的书架——二分答案+主席树
题目描述 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Co rmen 的文章.粟粟家中有一个 R行C 列的巨型书架,书架的每一个位 ...
- 【刷题】BZOJ 1926 [Sdoi2010]粟粟的书架
Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Cormen 的文章.粟粟家中有一个 R行C 列的巨型书架,书 ...
- 【BZOJ1926】【SDOI2010】粟粟的书架 [主席树]
粟粟的书架 Time Limit: 30 Sec Memory Limit: 552 MB[Submit][Status][Discuss] Description 幸福幼儿园 B29 班的粟粟是一 ...
随机推荐
- lucene和solr
我们为什么要用solr呢? 1.solr已经将整个索引操作功能封装好了的搜索引擎系统(企业级搜索引擎产品) 2.solr可以部署到单独的服务器上(WEB服务),它可以提供服务,我们的业务系统就只要发送 ...
- convertTo
转自 http://blog.csdn.net/xiaxiazls/article/details/51204265 在使用Opencv中,常常会出现读取一个图片内容后要把图片内容的像素信息转为浮点并 ...
- dataframe 用法总结
http://pda.readthedocs.io/en/latest/chp5.html data = [] 列表初始化 data = (,) data = {} 字典初始化 data = pd.D ...
- Django框架 之 form组件
Django框架 之 form组件 浏览目录 Form介绍 普通的登录 使用form组件 Form详情 常用字段 校验 进阶 使用Django Form流程 一.Form介绍 我们之前在HTML页面中 ...
- 如何恢复VS2013代码实时校验功能
VS2013在某一天突然无法进行实时代码校验了,只有在编译的时候,错误列表才显示语法错误 怎么来解决这个问题呢?试试环境重置吧. 首先:打开工具菜单,选择“导入和导出设置”. 其次:可以先导出选定 ...
- 树形DP-HDU1561 The more, The Better
很好的树形DP入门题,看着和选课那道题如出一辙. Problem Description ACboy很喜欢玩一种战略游戏,在一个地图上,有N座城堡,每座城堡都有一定的宝物,在每次游戏中ACboy允许攻 ...
- WP REST API: 设置和使用OAuth 1.0a Authentication(原文)
In the previous part of the series, we set up basic HTTP authentication on the server by installing ...
- C# winform使用cefsharp
注意事项写在开头: 一)cef要求.Net FrameWork框架最少为4.5.2,所以咱们在创建工程的时候注意 二)cef不支持anycpu平台 第一步: 新建工程 第二步 添加cef nuget ...
- angular 输出属性
import { Component, OnInit, EventEmitter, Output } from '@angular/core'; @Component({ selector: 'app ...
- 大数据技术之_11_HBase学习_01_HBase 简介+HBase 安装+HBase Shell 操作+HBase 数据结构+HBase 原理
第1章 HBase 简介1.1 什么是 HBase1.2 HBase 特点1.3 HBase 架构1.3 HBase 中的角色1.3.1 HMaster1.3.2 RegionServer1.3.3 ...