正解:单调栈/悬线法

解题报告:

ummm这题我当初做的时候一点思路也没有只会暴力出奇迹:D(啊听说暴力好像能水过去呢,,,

然后当初是看的题解,然后学了下悬线法

然后就忘了:D

然后我现在看发现看不懂辽:D

#论写题解的好处:D

所以赶紧来写个题解QAQ

ummm悬线法这个玩意儿会单独写个学习笔记的到时候放链接QAQ所以这里不详解了

反正这题就相当于是个最大子矩阵的玩意儿?有点悬线法板子题的意思蛤?

那如果知道悬线法就可以直接过了,好了没了感觉没太多可说的QAQ

然而这题谢总是布置在单调栈专题的

所以

单调栈解法了解一下?

ummm单调栈就大概想下就出来了?感觉没有悬线法那么难理解(所以我悬线法还没研究出来,,,ummm,,,,

首先做个前缀和记录每列从上往下累计的F的个数

然后就变成每行做一次单调栈(就是最大子矩阵单调栈板子题了qwq

然后就没了?

感觉说得好简陋鸭

那我再,仔细说下QAQ

就以样例为例做个解释

R F F F F F                0 1 1 1 1 1
F F F F F F                1 2 2 2 2 2
R R R F F F  于是可以做成   0 0 0 3 3 3
F F F F F F                1 1 1 4 4 4
F F F F F F                2 2 2 5 5 5

然后对每行当做最大子矩阵那题做个单调栈,就欧克了qwq

所以复杂度似乎是O(nm)?显然是可以过的qwq

然后代码在这儿qwq

#include<bits/stdc++.h>
using namespace std;
#define rp(i,x,y) for(register int i=x;i<=y;++i)

+;
int ans,t,fil[N][N],stck[N],lth[N],n,m;

inline int read()
{
    ,y=;
    ') && ch!='-')ch=getchar();
    ,ch=getchar();
    )+(x<<)+(ch^'),ch=getchar();
    return y?x:-x;
}
inline char readch()
{
    char ch=getchar();while(ch!='F' && ch!='R')ch=getchar();
    return ch;
}
inline ;memset(lth,,,,sizeof(stck));}
inline void work(int x)
{
    ;fil[x][m+]=;
    rp(i,,m+)
    {
        ;
        while(stck[tail]>fil[x][i])len+=lth[tail],ans=max(ans,len*stck[tail]),--tail;
        stck[++tail]=fil[x][i];lth[tail]=len+;
    }
}

int main()
{
    int T=read();
    while(T--)
    {
        n=read(),m=read();clr();
        rp(i,,n)
            rp(j,,m)
            {
                char ch=readch();
                +fil[i-][j];;
            }
        rp(i,,n)work(i);
        printf();
    }
    ;
}

对了,,,我发现这题还有几个神奇巴拉的题解?比如并茶几?比如前缀和巴拉巴拉的?还挺有趣的嘿可能有时间会了解下然后写题解趴qwq

然后今天讲题的时候还分享了个O(n3)的前缀和

就是之前考过的那个入阵曲那题的方法,降维,over

有时间自己写下然后放代码

先放个hl的丑陋代码qwq

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
inline int qr(void ){
    char c=getchar();
    ,q=;
    ||c>)
        q=c==?-:q,c=getchar();
    &&c<=)
        x=(x<<)+(x<<)+(c^),c=getchar();
    return q*x;
}
typedef long long ll;
;
#define RP(t,a,b)   for(int t=(a),edd=(b);t<=edd;t++)
ll ans;
ll data[maxn][maxn];
ll k,b;
int n,m;
inline void fakedp(void){
    RP(t0,,n)
        RP(t1,t0,n){
            k=;
            b=;
            RP(t,,m){
                ][t])==(t1-t0+))
                    k++,b=max(b,k);
                else
                    k=;
            }
            b*=(t1-t0+);
            ans=max(ans,b);
        }
}
char qaq;
int main(){
    n=qr();
    m=qr();
    RP(t,,n){
        RP(i,,m){
            qaq=getchar();
            while(qaq!='R'&&qaq!='F')
                qaq=getchar();
            if(qaq=='R')
                data[t][i]=+data[t-][i];
            else
                data[t][i]=+data[t-][i];
        }
    }
    fakedp();
    cout<<ans*;
}

丑陋代码

还有个是n2logn 的神仙方法?是lsy大佬之前港的,然而我之前找他要代码然后复制过来格式错了?然后我上ycg那题找他的记录感觉他是用的n2的?就很绝望QAQ先这样趴有时间再搞QAQ

洛谷P4147 玉蟾宫 单调栈/悬线法的更多相关文章

  1. [BZOJ 3039&洛谷P4147]玉蟾宫 题解(单调栈)

    [BZOJ 3039&洛谷P4147]玉蟾宫 Description 有一天,小猫rainbow和freda来到了湘西张家界的天门山玉蟾宫,玉蟾宫宫主蓝兔盛情地款待了它们,并赐予它们一片土地. ...

  2. 洛谷P4147 玉蟾宫(动规:最大子矩形问题/悬线法)

    题目链接:传送门 题目大意: 求由F构成的最大子矩阵的面积.输出面积的三倍. 1 ≤ N,M ≤ 1000. 思路: 悬线法模板题. #include <bits/stdc++.h> us ...

  3. P4147 玉蟾宫--单调栈

    P4147 玉蟾宫 题目背景 有一天,小猫rainbow和freda来到了湘西张家界的天门山玉蟾宫,玉蟾宫宫主蓝兔盛情地款待了它们,并赐予它们一片土地. 题目描述 这片土地被分成N*M个格子,每个格子 ...

  4. 洛谷 P4147 玉蟾宫 (最大子矩形问题)

    这道题用到了悬线法,非常牛逼,可以看这个论文. https://blog.csdn.net/twtsa/article/details/8120269 #include<cstdio> # ...

  5. 洛谷 P1169 [ZJOI2007]棋盘制作 (悬线法)

    和玉蟾宫很像,条件改成不相等就行了. 悬线法题目 洛谷 P1169  p4147  p2701  p1387 #include<cstdio> #include<algorithm& ...

  6. 【BZOJ-3039&1057】玉蟾宫&棋盘制作 悬线法

    3039: 玉蟾宫 Time Limit: 2 Sec  Memory Limit: 128 MBSubmit: 753  Solved: 444[Submit][Status][Discuss] D ...

  7. BZOJ_3039_玉蟾宫_(动态规划+悬线法)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=3039 n*m的矩阵由R和F组成,求全是F的子矩阵的大小的三倍. 分析 悬线法: 浅谈用极大化思 ...

  8. 洛谷P4147 玉蟾宫 (单调栈)

    要求我们去找一个最大矩形面积. 单调栈做法(和P1950 长方形那道题类似(一模一样)). 1 #include<bits/stdc++.h> 2 using namespace std; ...

  9. [洛谷P4147] 玉蟾宫

    类型:单调栈 传送门:>Here< 题意:求一个$01$矩阵中最大子矩形(全是$1$)的面积 解题思路 单调栈的一个经典应用 考虑维护一个数组$p[i][j]$表示$(i,j)$往上最多有 ...

随机推荐

  1. 执行RF测试只生成output.xml文件,不生成log和report文件

    命令格式: -l --log file HTML log file. Can be disabled by giving a special value `NONE`. Default: log.ht ...

  2. JavaWeb学习总结(十五)Jsp中提交的表单的get和post的两种方式

    两者的比较: Get方式: 将请求的参数名和值转换成字符串,并附加在原来的URL之后,不安全 传输的数据量较小,一般不能大于2KB: post方式: 数量较大: 请求的参数和值放在HTML的请求头中, ...

  3. C#编写中使用预编译指令代替不停的注释

    是不是经常调试某个模块的时候,要打开一堆Console或者Debug.Log,printf 不调试的时候,又关掉.如此繁复的倒腾实在是烦 可以使用预编译指令代替这种做法 #define 自定义字段 . ...

  4. ASP.NET MVC入门到精通——第一个ASP.NET MVC程序

    开发流程 新建Controller 创建Action 根据Action创建View 在Action获取数据并生产ActionResult传递给View. View是显示数据的模板 Url请求→Cont ...

  5. python 学习笔记---文件处理

    1.打开文件读取数据 f =open(“wenjian.txt”,"r") print(f) f.close() 直接变成列表--->list(f) for each_lin ...

  6. 《转载》renameTo文件在windows环境下可以,在linux中报错

    以前我一直以为File#renameTo(File)方法与OS下面的 move/mv 命令是相同的,可以达到改名.移动文件的目的.不过后来经常发现问题:File#renameTo(File)方法会返回 ...

  7. cvc-complex-type.2.4.c: The matching wildcard is strict, but no declaration的解决

    导入了一个工程,编译什么的都还好,但是报了一个XML的错误. cvc-complex-type.2.4.c: The matching wildcard is strict, but no decla ...

  8. Nginx七层反向代理和负载均衡

    1.介绍 1.1 Nginx不仅是一个出色的web软件,其七层代理和负载均衡也是相当出色.Nginx做前端代理,当用户请求服务时,可以根据url进行判断,然后分配到不同的后台webserver上. 1 ...

  9. GNU Readline库函数的应用示例

    说明 GNU Readline是一个跨平台开源程序库,提供交互式的文本编辑功能.应用程序借助该库函数,允许用户编辑键入的命令行,并提供自动补全和命令历史等功能.Bash(Bourne Again Sh ...

  10. C语言内存使用的常见问题及解决之道

    一  前言 本文所讨论的“内存”主要指(静态)数据区.堆区和栈区空间(详细的布局和描述参考<Linux虚拟地址空间布局>一文).数据区内存在程序编译时分配,该内存的生存期为程序的整个运行期 ...