MT3042 这项目我小码哥投了

 代码

1.暴力7/15:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 5e6 + 10;
int n, m;
char mp[1005][1005];
int main()
{
    cin >> n >> m;
    for (int i = 1; i <= n; i++)
    {
        for (int j = 1; j <= m; j++)
        {
            cin >> mp[i][j];
        }
    }
    int ans = 0;
    for (int i = 1; i <= n; i++) // 暴力枚举
    {
        for (int j = 1; j <= m; j++)
        {
            if (mp[i][j] == 'G') // 找到左上角是G的点
            {
                for (int k = i; k <= n; k++)
                {
                    for (int l = j; l <= m; l++)
                    {
                        int flag = 1;                // flag是标记是否有R
                        for (int x = i; x <= k; x++) // i k j l是矩形的左上,右上,左下,右下
                        {
                            for (int y = j; y <= l; y++)
                            {
                                if (mp[x][y] == 'R')
                                {
                                    flag = 0;
                                    break;
                                }
                            }
                            if (flag == 0)
                            {
                                break;
                            }
                        }
                        if (flag == 1)
                        {
                            ans = max(ans, (k - i + 1) * (l - j + 1));
                        }
                    }
                }
            }
        }
    }
    cout << ans * 10;
}

2.单调栈15/15

矩阵可以根据不同的行看成直方图: 

 

(图源b站up主:轩哥码题) 

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1e3 + 10;
int n, m, a[N][N], ans;
char ch;
// 单调栈,找右边第一个比自己小的数
// 栈顶元素>=要进来的元素:栈顶元素出栈
// 如果有元素出栈,则右边界为要进来的元素位置,左边界为栈中上一个元素位置
// 将二维平面看成不同的一维数组,对每一行进行单调栈操作
int maxRec(int x)
{ // 使用单调栈求某行作为x轴的最大矩形面积
    int ret = 0;
    stack<int> s;
    s.push(0);
    for (int i = 1; i <= m + 1; i++) // i:位置
    {
        while (a[x][i] < a[x][s.top()]) // 如果有元素出栈
        {
            int h = a[x][s.top()];
            s.pop();
            int w = i - s.top() - 1; // 宽度
            ret = max(ret, w * h);
        }
        s.push(i);
    }
    return ret;
}
int main()
{

    cin >> n >> m;
    for (int i = 1; i <= n; i++)
    {
        for (int j = 1; j <= m; j++)
        {
            cin >> ch;
            if (ch == 'G')
                a[i][j] = 1;
        }
    }
    for (int i = 1; i <= n; i++)
    {
        for (int j = 1; j <= m; j++)
        {
            if (a[i][j])//a[i][j]是G,才算有效
                a[i][j] += a[i - 1][j];
        }
    }
    for (int i = 1; i <= n; i++)
    {
        ans = max(ans, maxRec(i));
    }
    cout << ans * 10;
    return 0;
}

3.动态规划15/15

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define INF 0x3f3f3f3f
int n, m;
char aij;
ll sum[1005][1005], ans, temp;
// 动态规划,将二维转为一维
// 思路:R点设为负无穷大,二维用前缀和转移成一维,求一维的最大连续子序列
int main()
{
    cin >> n >> m;
    for (int i = 1; i <= n; i++)
    {
        for (int j = 1; j <= m; j++)
        {
            cin >> aij;
            if (aij == 'R')
                temp = -INF;
            else
                temp = 10;
            sum[i][j] = sum[i - 1][j] + temp;
        }
    }
    for (int i = 1; i <= n; i++)
    {
        for (int j = i; j <= n; j++)
        {
            ll sum1 = 0;
            for (int k = 1; k <= m; k++)
            {
                sum1 += sum[j][k] - sum[i - 1][k];
                if (sum1 < 0)
                {
                    sum1 = 0;
                }
                ans = max(ans, sum1);
            }
        }
    }
    cout << ans;
}

  • 37
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
我很高兴回答你关于“MT源码修改教程”的问题。 MT源码是Movable Type(MT)博客平台的开源代码,它是一个功能强大的博客发布系统。在修改MT源码之前,首先要确保你对代码修改有一定的了解和技术能力,以避免不必要的错误。 首先,你可以通过下载MT源码并解压缩来开始修改。你可以在MT的官方网站上找到MT源码的下载链接。一旦下载完成,你可以使用编辑器打开源码文件,开始探索和修改代码。 MT源码修改的具体步骤会因你想要实现的功能而有所不同。但是,无论你想要对博客主题、插件、功能模块还是后台管理界面进行修改,都需要对相关的源码文件进行编辑。 在修改源码之前,最好先备份所有相关的文件,以备修改出错时恢复使用。然后,你需要通过研究源码文件、阅读相关文档和使用开发工具,来找到你想要修改的具体代码部分。 一旦找到目标代码部分,你可以使用合适的编程语言知识和工具,进行修改和调试。在进行修改时,要注意代码的正确性和可读性,以避免引入新的问题。 修改完成后,你可以将修改后的源码文件重新上传到你的服务器上,并测试它们是否按照你的期望运行。如果出现问题,你可以通过源码版本控制工具或备份文件进行回滚,直至问题解决。 总之,MT源码修改是一个需要技术功底和编程知识的过程,但通过仔细研究和实践,你可以实现与MT博客平台相关的个性化需求。希望这些简要的指导对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值