Poetize4 玉蟾宫
来源:互联网 发布:mac虚拟机使用经验 编辑:程序博客网 时间:2024/04/27 20:48
题目大意:给你一个N行M列的地,每块地上有R或F,求这个图中最大的由F构成的矩形面积 n,m<=1000
这道题,如果给定你矩形的下底所在的行,那么我们就用一个单调栈维护,即可,然后枚举矩形的下底所在的行 O(n^2)
#include<cstdio>#include<cstring>const int maxn=1010; using namespace std;inline int max(int a,int b){return a>b?a:b;}int n,m;int s[maxn];int h[maxn][maxn];int len[maxn];int main(){scanf("%d%d",&n,&m);for (int i=1;i<=n;++i)for (int j=1;j<=m;++j){char tmp=1;while (!(tmp=='F' || tmp=='R'))tmp=getchar();if (tmp=='F')h[i][j]=h[i-1][j]+1;}int ans=0;for (int i=1;i<=n;++i){memset(len,0,sizeof(len));int tot(0);for (int j=1;j<=m;++j){if (!tot || h[i][j]>=h[i][s[tot]]){s[++tot]=j;len[j]=1;continue;}len[j]=0;for (;h[i][j]<h[i][s[tot]];--tot)len[j]+=len[s[tot]],ans=max(ans,h[i][s[tot]]*len[j]);len[j]++;s[++tot]=j;}int xx=0;for (;tot;--tot)xx+=len[s[tot]],ans=max(ans,h[i][s[tot]]*xx);}printf("%d\n",ans*3);return 0;}
- Poetize4 玉蟾宫
- [单调栈]「Poetize4」玉蟾宫
- TYVJ 1939 「Poetize4」玉蟾宫
- Tyvj P1939「Poetize4」玉蟾宫
- 玉蟾宫
- 3039: 玉蟾宫
- BZOJ 3039: 玉蟾宫
- BZOJ3039 玉蟾宫
- [BZOJ3039] 玉蟾宫
- bzoj3039 玉蟾宫
- code vs玉蟾宫
- 【bzoj3039】玉蟾宫
- tyvj1939 玉蟾宫
- tyvj p1939玉蟾宫
- bzoj 3039 玉蟾宫
- CODEVS 2491 玉蟾宫
- 【codevs 2491】玉蟾宫
- bzoj3039玉蟾宫
- Hibernate中save方法无报错无法保存及@Transactional注解的意义
- 数字地和模拟地处理的连接和处理
- mybatis(上篇)
- Tomcat老是自动死掉报内存溢出错误怎么解决?
- 并发机制之线程1
- Poetize4 玉蟾宫
- 安卓远程工具 Android Remote
- Java中的陷阱
- 如何在QQ中输入繁体字
- 蓝牙状态的监听
- ADT Bundle – Just a single step to setup android development environment
- mybatis(下篇)
- android自定义键盘
- extjs-dataProxy