题目描述

回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢(猫猫就是这么可爱,吃鱼也要想好吃法 ^_*)。她发现,把大池子视为01矩阵(0表示对应位置无鱼,1表示对应位置有鱼)有助于决定吃鱼策略。

在代表池子的01矩阵中,有很多的正方形子矩阵,如果某个正方形子矩阵的某条对角线上都有鱼,且此正方形子矩阵的其他地方无鱼,猫猫就可以从这个正方形子矩阵“对角线的一端”下口,只一吸,就能把对角线上的那一队鲜鱼吸入口中。

猫猫是个贪婪的家伙,所以她想一口吃掉尽量多的鱼。请你帮猫猫计算一下,她一口下去,最多可以吃掉多少条鱼?

输入输出格式

输入格式:

有多组输入数据,每组数据:

第一行有两个整数n和m(n,m≥1),描述池塘规模。接下来的n行,每行有m个数字(非“0”即“1”)。每两个数字之间用空格隔开。

对于30%的数据,有n,m≤100

对于60%的数据,有n,m≤1000

对于100%的数据,有n,m≤2500

输出格式:

只有一个整数——猫猫一口下去可以吃掉的鱼的数量,占一行,行末有回车。

--------------------------------------------我是分割线------------------------------------------------

这题我用的是N2logN的二分,还挺好写的,效率也很可观。

进入正题:

首先要对角线要分成两种,一种是/这样的,一种是\这样的(灵魂题解~~),这是两个相似的问题,我们可以先解决一个,然后把代码复制一下(嘿嘿嘿)。

我们来看一下\这样的对角线,式子很明显:

f[i][j]表示以(i,j)为终点的对角线长度,因此这里一定有要鱼

如果矩阵(i-x,j-x,i,j)是满足题目要求的,那么f[i][j]=max(f[i][j],x)。

同时我们发现,1.x越大越好。2.x的上界是f[i-1][j-1],因为超过这个一定不满足要求。3.如果x不满足要求,那么x到其上界就都不满足。

似乎满足单调性?

那么我们可以二分x。

之后我们再来看满足题目要求的矩阵

举个例子:

1 0 0 0

0 1 0 1

0 0 1 0

0 0 0 1

当i=4,j=4时,由于我们之前算出来f[3][3]是三,那么矩阵(1,1,3,3)一定是符合要求的,所以我们只需要判断第i行1到j个元素与第j行1到i个元素有没有鱼就可以了。

但如果暴力算的话会T,我们可以算矩阵(i-x,j-x,i,j)的和是不是x+1。于是就可以用到我们的二维前缀和了。

贴一下代码:

#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
int f[][],s[][],i;
int a[][],n,m,l,r,mid,ans,j;
inline int read(){
int x=,p=; char ch=getchar();
while (ch<''||ch>'') {if (ch == '-') p=-; ch=getchar();}
while (ch>=''&&ch<='') {x=(x<<)+(x<<)+ch-''; ch=getchar();}
return x*p;
}
int main(){
n=read(); m=read();
for (i=; i<=n; i++)
for (j=; j<=m; j++){
a[i][j]=read();
s[i][j]=s[i-][j]+s[i][j-]-s[i-][j-]+a[i][j];
}
for (i=; i<=n; i++)
for (j=; j<=m; j++){
if (a[i][j]){
f[i][j]=;
if (f[i-][j-]){
l=; r=f[i-][j-];
while (l<=r){
mid=l+r>>;
if (s[i][j]-s[i-mid-][j]-s[i][j-mid-]+s[i-mid-][j-mid-]==mid+)
l=mid+;
else r=mid-;
}
f[i][j]=max(f[i][j],l);
}
}
ans=max(ans,f[i][j]);
}
memset(f,,sizeof(f));
for (i=; i<=n; i++)
for (j=m; j>=; j--){
if (a[i][j]){
f[i][j]=;
l=; r=f[i-][j+];
while (l<=r){
mid=l+r>>;
if (s[i][j+mid]-s[i][j-]-s[i-mid-][j+mid]+s[i-mid-][j-]==mid+)
l=mid+;
else r=mid-;
}
f[i][j]=max(f[i][j],l);
}
ans=max(ans,f[i][j]);
}
printf("%d",ans);
return ;
}

洛谷 P1736 创意吃鱼法(多维DP)的更多相关文章

  1. 洛谷 P1736 创意吃鱼法

    题目描述 题目链接:https://www.luogu.org/problemnew/show/P1736 回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢( ...

  2. 洛谷 P1736 创意吃鱼法 Label:dp || 前缀和

    题目描述 回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢(猫猫就是这么可爱,吃鱼也要想好吃法 ^_*).她发现,把大池子视为01矩阵(0表示对应位置无鱼,1 ...

  3. 洛谷P1736 创意吃鱼法

    题目描述 回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢(猫猫就是这么可爱,吃鱼也要想好吃法 ^_*).她发现,把大池子视为01矩阵(0表示对应位置无鱼,1 ...

  4. 洛谷P1736 创意吃鱼法 dp

    正解:dp 解题报告: 早就想写dp的题目辣!我发现我的dp好差啊QAQ所以看到列表的小朋友写dp的题目就跟着他们的步伐做下题好辣QwQ 这题的话没有那——么难,大概说下趴QwQ 首先说下题意 前面一 ...

  5. P1736 创意吃鱼法[二维dp]

    题目背景 感谢@throusea 贡献的两组数据 题目描述 回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢(猫猫就是这么可爱,吃鱼也要想好吃法 ^_*).她 ...

  6. P1736 创意吃鱼法 图的DP

    题目描述 回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢(猫猫就是这么可爱,吃鱼也要想好吃法 ^_*).她发现,把大池子视为01矩阵(0表示对应位置无鱼,1 ...

  7. P1387 最大正方形&&P1736 创意吃鱼法

    P1387 最大正方形 P1736 创意吃鱼法 两道类似的$DP$ 转移方程基本上类似于$f[i][j]=min(f[i-1][j-1],min(f[i][j-1],f[i-1][j]))$ 考虑构成 ...

  8. P1736 创意吃鱼法

    题目描述 回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢(猫猫就是这么可爱,吃鱼也要想好吃法 ^_*).她发现,把大池子视为01矩阵(0表示对应位置无鱼,1 ...

  9. P1736 创意吃鱼法80

    题目描述 回到家中的猫猫把三桶鱼全部转移到了她那长方形大池子中,然后开始思考:到底要以何种方法吃鱼呢(猫猫就是这么可爱,吃鱼也要想好吃法 ^_*).她发现,把大池子视为01矩阵(0表示对应位置无鱼,1 ...

随机推荐

  1. mysql必知必会学习笔记(1)

    chapter 13 13.1 数据分组 如果要将数据分为多个逻辑组怎么办?? 要用数据分组 13.2 创建分组 使用group by子句.group by会指示对mysql进行分组,然后对每个组进行 ...

  2. IE6/IE7下只设置margin-left,左右都有边距问题

    CSS代码 div { border: 1px solid red; } .inner { width: 80px; height: 80px; float: left; position: rela ...

  3. tomcat的备份脚本

    reference:Crontab的20个例子  先科普一下date的使用方法,在sh脚本中经常会使用得到 date -d<字符串>:显示字符串所指的日期与时间.字符串前后必须加上双引号: ...

  4. 【转】如何在Git中撤销一切

    翻译:李伟 审校:张帆译自:Github 任何一个版本控制系统中,最有用的特性之一莫过于 “撤销(undo)”操作.在Git中,“撤销”有很多种含义. 当你完成了一次新的提交(commit),Git会 ...

  5. WIN10+Ubuntu14.04 双系统 ubuntu无法有线上网的问题

    注:在WIN10 的引导下安装了双系统,ubuntu有线无法上网,无线却可以. 上网一查,发现之前许多安装双系统的人都存在以上的问题. 常见的解决方法是: 在WINDOWS下关闭网络唤醒,还有一些检查 ...

  6. SAP云平台CloudFoundry中的用户自定义变量

    CloudFoundry应用的manifest.xml里的env区域,允许用户自定义变量,如下图5个变量所示. 使用cf push部署到CloudFoundry之后,在SAP Cloud Platfo ...

  7. UVA Live Achrive 4327 Parade (单调队列,dp)

    容易想到dp[i][j]表示在第i行j个路口的开始走最大高兴值. 每次可以向左走,或者向右边走,然后向北走.(或者直接往北) 向左走到,状态转移为dp[i][j] = dp[i][k] + happy ...

  8. 在RichTextBox控件中显示RTF格式文件

    实现效果: 知识运用:    RichTextBox控件的LoadFile方法 //将文件内容加载到RichTextBox控件中 public void LoadFile(string path,Ri ...

  9. Python监控日志中经常访问的ip

    一.需求:每分钟检查一次日志文件,如果这一分钟内同一个ip请求次数超过200次,加入黑名单 1.日志文件中,每一行的格式为:XXX.XXX.XXX.XXX - - [04/Jun/2017:05:25 ...

  10. CUDA编程时,线程块的处理方法