bzoj 1926: [Sdoi2010]粟粟的书架
#include<cstdio>
#include<iostream>
#define N 201
#define M 500008
using namespace std;
int cnt,r,c,m,ls[*M],rs[*M],root[M],ans,sum[*M],sum1[*M],shu,num[][N][N],num1[][N][N];
void jia(int l,int r,int x,int &y,int v)
{
y=++cnt;
sum[y]=sum[x]+v;
sum1[y]=sum1[x]+;
if(l==r)
return;
ls[y]=ls[x];
rs[y]=rs[x];
int mid=(l+r)>>;
if(v<=mid)
jia(l,mid,ls[x],ls[y],v);
else
jia(mid+,r,rs[x],rs[y],v);
return;
}
int xun(int a1,int a2,int l,int r,int v)
{
if(!a1)
return ;
if(l>=v)
{
shu-=sum[a1]-sum[a2];
return sum1[a1]-sum1[a2];
}
int s=,mid=(l+r)>>;
if(mid>=v)
s+=xun(ls[a1],ls[a2],l,mid,v);
s+=xun(rs[a1],rs[a2],mid+,r,v);
return s;
}
void solve1()
{
for(int i=;i<=c;i++)
{
int a1;
scanf("%d",&a1);
jia(,,root[i-],root[i],a1);
}
for(int i=;i<=m;i++)
{
int x0,y0,x1,y1,v;
scanf("%d%d%d%d%d",&x0,&y0,&x1,&y1,&v);
int l=,r=,mid=(l+r)>>,b1,md,md1;
ans=;
for(;l<=r;)
{
shu=v;
b1=xun(root[y1],root[y0-],,,mid);
if(shu<=)
{
md1=v-shu;
md=mid;
ans=b1;
l=mid+;
}
else
r=mid-;
mid=(l+r)>>;
}
if(!ans)
printf("Poor QLW\n");
else
{
int a1;
r=xun(root[y1],root[y0-],,,md+);
r=ans-r;
l=;
mid=(l+r)>>;
for(;l<=r;)
{
if(md1-mid*md>=v)
{
a1=ans-mid;
l=mid+;
}
else
r=mid-;
mid=(l+r)>>;
}
printf("%d\n",a1);
}
}
return;
}
void solve2()
{
for(int i=;i<=r;i++)
for(int j=;j<=c;j++)
{
int a1;
scanf("%d",&a1);
for(int k=;k<=;k++)
{
num[k][i][j]=(num[k][i][j-]+num[k][i-][j]-num[k][i-][j-]);
num1[k][i][j]=(num1[k][i][j-]+num1[k][i-][j]-num1[k][i-][j-]);
if(a1>=k)
{
num[k][i][j]+=a1;
num1[k][i][j]++;
}
}
}
for(int i=;i<=m;i++)
{
int x0,y0,x1,y1,v;
scanf("%d%d%d%d%d",&x0,&y0,&x1,&y1,&v);
int l=,r=,mid=(l+r)>>,tm=,tm1=,tm2=;
for(;l<=r;)
{
if(num[mid][x1][y1]-num[mid][x1][y0-]-num[mid][x0-][y1]+num[mid][x0-][y0-]>=v)
{
tm=num1[mid][x1][y1]-num1[mid][x1][y0-]-num1[mid][x0-][y1]+num1[mid][x0-][y0-];
tm1=mid;
l=mid+;
}
else
r=mid-;
mid=(l+r)>>;
}
if(!tm)
printf("Poor QLW\n");
else
{
tm2=num[tm1][x1][y1]-num[tm1][x1][y0-]-num[tm1][x0-][y1]+num[tm1][x0-][y0-];
l=,r=num1[tm1+][x1][y1]-num1[tm1+][x1][y0-]-num1[tm1+][x0-][y1]+num1[tm1+][x0-][y0-];
r=tm-r;
mid=(l+r)>>;
for(;l<=r;)
{
if(tm2-mid*tm1>=v)
{
ans=tm-mid;
l=mid+;
}
else
r=mid-;
mid=(l+r)>>;
}
printf("%d\n",ans);
}
}
return;
}
int main()
{
scanf("%d%d%d",&r,&c,&m);
if(r==)
solve1();
else
solve2();
return ;
}
两种情况 对于R,C<=200,用前缀和暴力二分,对于另外的数据,在主席树上二分。
bzoj 1926: [Sdoi2010]粟粟的书架的更多相关文章
- 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]粟粟的书架
Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Cormen 的文章.粟粟家中有一个 R行C 列的巨型书架,书 ...
- BZOJ 1926: [Sdoi2010]粟粟的书架(主席树,二分答案)
BZOJ 1926: [Sdoi2010]粟粟的书架(主席树,二分答案) 题意 : 给你一个长为\(R\)宽为\(C\)的矩阵,第\(i\)行\(j\)列的数为\(P_{i,j}\). 有\(m\)次 ...
- BZOJ.1926.[SDOI2010]粟粟的书架(前缀和 主席树 二分)
题目链接 题意: 在给定矩形区域内找出最少的数,满足和>=k.输出数的个数.两种数据范围. 0~50 注意到(真没注意到...)P[i,j]<=1000,我们可以利用前缀和预处理. num ...
- 粟粟的书架(bzoj 1926)
Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Co rmen 的文章.粟粟家中有一个 R行C 列的巨型书架, ...
- bzoj1926[Sdoi2010]粟粟的书架 二分 主席树
1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Sec Memory Limit: 552 MBSubmit: 1064 Solved: 421[Submit][Stat ...
- [BZOJ1926][SDOI2010]粟粟的书架
BZOJ Luogu Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱的小朋友,她的爱好是画画和读书,尤其喜欢 Thomas H. Cormen 的文章.粟粟家中有一个 R ...
- BZOJ1926:[SDOI2010]粟粟的书架——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=1926 https://www.luogu.org/problemnew/show/P2468 幸福幼 ...
随机推荐
- 优秀c++开源项目集合
本文会持续更新, 我希望通过这篇文章把我看到过的优秀开源项目记录下来, 有时间仔细阅读. cockroachdb 前googler开发的开源的spanner数据库: https://github.co ...
- HDU5807分段dp
DAG图. [题意] n(50)个城市m(c(n,2))条单向边(x,y),保证x<y 对于三个点(x,y,z)如果abs(w[x]-w[y])<=K && abs(w[x ...
- js原型链闭包作用域链-Tom
1.原型相当于Java.C++里面的父类,由封装公有属性及方法而产生,子类可以继承. 原型继承实现(函数的原型属性指向原型函数一个实例对象,函数的原型的构造函数指向函数本身) 1)eg:原型链 fun ...
- poj3565Ants(KM-几何与图论的结合)
链接 可以看出蓝的之和一定比红的之和要大,也就是说符合条件的匹配一定是权值最小的,所以二分图的最佳完美匹配..KM #include <iostream> #include<cstd ...
- number-of-segments-in-a-string
https://leetcode.com/problems/number-of-segments-in-a-string/ package com.company; class Solution { ...
- swift语言学习之UITableView分割线左边到头的解决
此方法兼容ios 7.8.9 // 在tableView创建地方设置 if tableView!.respondsToSelector("setSeparatorInset:") ...
- iOS开发之 获取手机的网络的ip地址
首先在使用的地方导入 #include <ifaddrs.h> #include <arpa/inet.h> 然后直接调用 - (NSString *)getIPAddress ...
- [js] 跨域
原文链接:http://www.cnblogs.com/scottckt/archive/2011/11/12/2246531.html 什么是跨域? 首先什么是跨域,简单地理解就是因为JavaScr ...
- hdu5785(极角排序求所有锐角钝角个数)
做法很显然,求出所有的锐角和钝角就能求出有多少个锐角三角形了. 我用了愚钝的方法,写了两三个小时... 看了下别人简单的代码.学习了下做法. sort(temp+,temp+cnt+);//排序 Fo ...
- 关于json的理解
一. 获取数组长度 array.length 获取对象长度 Object.keys(objs).length 二. 如何抉择{}和[] 先说两者区别, {}:父类下面直接是子类名称 []:父类下会追 ...