HJ172 小红的矩阵染色

  • 题目
  • 题解(23)
  • 讨论(6)
  • 排行

简单 通过率:31.75% 时间限制:1秒 空间限制:256M

知识点贪心

校招时部分企业笔试将禁止编程题跳出页面,为提前适应,练习时请使用在线自测,而非本地IDE。

描述

给定一个 n×mn×m 的矩阵,初始时部分格子已被染成黑色 (用 ``**`` 表示),其余格子为空白(用 ``oo`` 表示)。

小红最多可以任选至多 kk 个空白 格子,将其染成红色 。计分规则如下:

∙ ∙ 若某个红色格子的正下方 (同一列下一行)也是红色,则该格子贡献 11 分;

∙ ∙ 其他情况不计分。

请你帮小红计算,经过最优染色后,最多能获得多少分数。

输入描述:

第一行输入三个整数 n,m,k(1≦n,m≦103; 1≦k≦n×m)n,m,k(1≦n,m≦103; 1≦k≦n×m),分别表示矩阵行数、列数及最多可染红的格子数量。

此后 nn 行,每行输入一个长度为 mm 的字符串 sisi​,描述第 ii 行初始状态:

∙ ∙ ``**`` 代表黑色格子,不能重新染色;

∙ ∙ ``oo`` 代表空白格子,可选择染为红色。

输出描述:

输出一个整数,表示小红通过最佳策略能够获得的最大分数。

示例1

输入:

复制代码
4 4 3
*o*o
oooo
****
oooo

复制输出:

复制代码
1

复制说明:

复制代码
一种可行方案如下(``rr`` 为染成红色后的格子):

*r*o
oroo
****
oooo

红色格子共有 22 个,其中正下方同列的红色对数为 11,因此得分 11。

示例2

输入:

复制代码
3 3 3
*o*
*o*
*o*

复制输出:

复制代码
2
cpp 复制代码
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <functional>

using namespace std;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(NULL);

    int n, m;
    long long k;
    cin >> n >> m >> k;

    vector<string> matrix(n);
    for (int i = 0; i < n; ++i) {
        cin >> matrix[i];
    }

    vector<int> chain_lengths;
    for (int j = 0; j < m; ++j) {
        int consecutive_white = 0;
        for (int i = 0; i < n; ++i) {
            if (matrix[i][j] == 'o') {
                consecutive_white++;
            } else {
                if (consecutive_white > 0) {
                    chain_lengths.push_back(consecutive_white);
                }
                consecutive_white = 0;
            }
        }
        if (consecutive_white > 0) {
            chain_lengths.push_back(consecutive_white);
        }
    }

    sort(chain_lengths.begin(), chain_lengths.end(), greater<int>());

    long long score = 0;
    for (int len : chain_lengths) {
        if (k <= 0) break;
        long long to_color = min((long long)len, k);
        k -= to_color;
        if (to_color > 1) {
            score += to_color - 1;
        }
    }

    cout << score << endl;

    return 0;
}
相关推荐
2301_822703202 小时前
Flutter 框架跨平台鸿蒙开发 - 智能植物生长记录应用
算法·flutter·华为·harmonyos·鸿蒙
每日任务(希望进OD版)2 小时前
线性DP、区间DP
开发语言·数据结构·c++·算法·动态规划
charlie1145141912 小时前
嵌入式C++教程实战之Linux下的单片机编程(9):HAL时钟使能 —— 不开时钟,外设就是一坨睡死的硅
linux·开发语言·c++·单片机·嵌入式硬件·c
放羊郎2 小时前
机器人跟随算法
算法·机器人
liu****2 小时前
第十五届蓝桥杯大赛软件赛国赛C/C++大学B组
c++·算法·蓝桥杯·acm
zhooyu2 小时前
利用叉乘判断OpenGL中的左右关系
c++·3d·opengl
We་ct2 小时前
LeetCode 172. 阶乘后的零:从暴力到最优,拆解解题核心
开发语言·前端·javascript·算法·leetcode·typescript
轻微的风格艾丝凡2 小时前
三相不平衡电流调试经验记录
算法·dsp
老虎06273 小时前
LeetCode热题100 刷题笔记(第五天)双指针法 「 三数之和 」
笔记·算法·leetcode