Acwing 3487. 最小面积子矩阵 && 3505. 最长ZigZag子序列

3487. 最小面积子矩阵 - AcWing题库

思路:二维矩阵前缀和,暴力枚举最小值

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

const int M = 110;
int g[M][M];

int main() {
    int n, m, k;
    cin >> n >> m >> k;
    for (int i = 1; i <= n; i ++) {
        for (int j = 1; j <= m; j ++) {
            cin >> g[i][j];
            g[i][j] += g[i - 1][j] + g[i][j - 1] - g[i - 1][j - 1];
        }
    }
    
    int res = INT_MAX;
    
    for(int i = 1; i <= n; i++) {
        for(int j = 1; j <= m; j++) {
            for(int x = i; x <= n; x++){
                for(int y = j; y <= m; y++) {
                    int sum = g[x][y] - g[i - 1][y] - g[x][j - 1] + g[i - 1][j - 1];
                    if(sum >= k) {
                        res = min(res, (x - i + 1) * (y - j + 1));
                    }
                }
            }
        }
    }
    if(res == INT_MAX) {
        cout << -1 << endl;
    }else {
        cout << res << endl;
    }
    return 0;
}

3505. 最长ZigZag子序列 - AcWing题库

cpp 复制代码
#include <iostream>
using namespace std;

const int N = 60;
int nums[N];
int dp[N][2];

int main() {
    int n = 0;
    cin >> n;
    for(int i = 1; i <= n; i++) {
        cin >> nums[i];
    }

    for(int i = 1;i <= n; i++){
        dp[i][0] = 1;
        dp[i][1] = 1;
        for(int j = 1;j < i; j++){
            if(nums[i] > nums[j])   dp[i][1] = max(dp[i][1], dp[j][0]+1);
            if(nums[i] < nums[j])   dp[i][0] = max(dp[i][0], dp[j][1]+1);
        }
    }
    cout << max(dp[n][0], dp[n][1]) << endl;
    return 0;
}
相关推荐
EterNity_TiMe_1 分钟前
【论文复现】(CLIP)文本也能和图像配对
python·学习·算法·性能优化·数据分析·clip
长弓聊编程3 分钟前
Linux系统使用valgrind分析C++程序内存资源使用情况
linux·c++
cherub.10 分钟前
深入解析信号量:定义与环形队列生产消费模型剖析
linux·c++
机器学习之心12 分钟前
一区北方苍鹰算法优化+创新改进Transformer!NGO-Transformer-LSTM多变量回归预测
算法·lstm·transformer·北方苍鹰算法优化·多变量回归预测·ngo-transformer
yyt_cdeyyds23 分钟前
FIFO和LRU算法实现操作系统中主存管理
算法
暮色_年华24 分钟前
Modern Effective C++item 9:优先考虑别名声明而非typedef
c++
重生之我是数学王子32 分钟前
QT基础 编码问题 定时器 事件 绘图事件 keyPressEvent QT5.12.3环境 C++实现
开发语言·c++·qt
daiyang123...1 小时前
测试岗位应该学什么
数据结构
alphaTao1 小时前
LeetCode 每日一题 2024/11/18-2024/11/24
算法·leetcode
我们的五年1 小时前
【Linux课程学习】:进程程序替换,execl,execv,execlp,execvp,execve,execle,execvpe函数
linux·c++·学习