[蓝桥杯]整理玩具

news2025/6/8 4:36:24

整理玩具

题目描述

小明有一套玩具,一共包含 N×MN×M 个部件。这些部件摆放在一个包含 N×MN×M 个小格子的玩具盒中,每个小格子中恰好摆放一个部件。

每一个部件上标记有一个 0 ~ 9 的整数,有可能有多个部件标记相同的整数。

小明对玩具的摆放有特殊的要求:标记相同整数的部件必须摆在一起,组成一个矩形形状。

如以下摆放是满足要求的:

00022

00033

44444

12244

12244

12233

01234

56789

以下摆放不满足要求:

11122

11122

33311

111111

122221

122221

111111

11122

11113

33333

给出一种摆放方式,请你判断是否符合小明的要求。

输入描述

输入包含多组数据。

第一行包含一个整数 T (1≤T≤10)T (1≤T≤10),代表数据组数。

以下包含 TT 组数据。

每组数据第一行包含两个整数 N,M (1≤N,M≤10)N,M (1≤N,M≤10)。

以下包含 NN 行 MM 列的矩阵,代表摆放方式。

输出描述

对于每组数据,输出 YES 或者 NO 代表是否符合小明的要求。

输入输出样例

示例

输入

3
3 5
00022
00033
44444
3 5
11122
11122
33311
2 5
01234
56789

输出

YES
NO
YES

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 256M

总通过次数: 256  |  总提交次数: 324  |  通过率: 79%

难度: 困难   标签: 2018, 暴力, 思维, 国赛

算法思路

题目要求判断给定的 N×M 矩阵中,相同数字的部件是否都聚集在一个完整的矩形区域内。核心思路是通过计算每个数字的边界矩形,并验证该矩形内是否完全被该数字填充。

关键步骤:
  1. ​边界计算​​:对于每个数字(0~9),计算其出现位置的最小行、最大行、最小列、最大列,形成一个边界矩形。
  2. ​面积验证​​:计算边界矩形的面积(行差×列差),并与该数字的出现次数比较:
    • 若面积 = 出现次数 → 数字恰好填满矩形(合法)
    • 若面积 ≠ 出现次数 → 矩形内有其他数字或数字分散(非法)

​数学原理​​:
设数字 d 的边界矩形面积为 S = (max_r - min_r + 1) × (max_c - min_c + 1)
若 S = count[d],则矩形内无空隙且无非 d 元素(因空隙会减少 d 的实际数量)

示例演示
┌───────────┐
│ 初始化队列 │
│ dist[0]=0  │
└─────┬─────┘
      │
      ▼
┌───────────┐     出队0      ┌───────────┐
│ 队列状态:  │ ───────────▶ │ 扩展邻居: │
│   [0]     │               │ +1→1, +k→3│
└───────────┘               └─────┬─────┘
      │                           │
      ▼                           ▼
┌───────────┐     入队1,3    ┌───────────┐
│ 队列状态:  │ ◀──────────── │ 更新距离: │
│  [1, 3]   │               │ dist[1]=1 │
└───────────┘               │ dist[3]=1 │
      │                     └───────────┘
      │
      ▼
┌───────────┐     出队1      ┌───────────┐
│ 扩展邻居: │ ───────────▶ │ +1→2, +k→4│
└─────┬─────┘               └─────┬─────┘
      │                           │
      ▼                           ▼
┌───────────┐     入队2,4    ┌───────────┐
│ 队列状态:  │ ◀──────────── │ 更新距离: │
│  [3,2,4]  │               │ dist[2]=2 │
└───────────┘               │ dist[4]=2 │
      │                     └───────────┘
      ▼
┌───────────┐     遍历完成    ┌───────────┐
│ 最终dist: │ ───────────▶ │ 0:0,1:1 │
│ [0,1,2,1,2]│               │ 2:2,3:1,4:2│
└───────────┘               └───────────┘

完整代码

#include <iostream>
#include <vector>
#include <climits>
using namespace std;

int main() {
    int T;
    cin >> T;
    while (T--) {
        int n, m;
        cin >> n >> m;
        vector<string> grid(n);
        for (int i = 0; i < n; i++) {
            cin >> grid[i];
        }

        // 初始化边界和计数器
        vector<int> min_r(10, INT_MAX);
        vector<int> max_r(10, INT_MIN);
        vector<int> min_c(10, INT_MAX);
        vector<int> max_c(10, INT_MIN);
        vector<int> count(10, 0);

        // 遍历矩阵更新边界
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                char c = grid[i][j];
                int num = c - '0';
                count[num]++;
                if (i < min_r[num]) min_r[num] = i;
                if (i > max_r[num]) max_r[num] = i;
                if (j < min_c[num]) min_c[num] = j;
                if (j > max_c[num]) max_c[num] = j;
            }
        }

        bool valid = true;
        for (int d = 0; d < 10; d++) {
            if (count[d] == 0) continue; // 跳过未出现的数字

            // 计算矩形面积
            int rows = max_r[d] - min_r[d] + 1;
            int cols = max_c[d] - min_c[d] + 1;
            int area = rows * cols;

            if (area != count[d]) {
                valid = false;
                break;
            }
        }

        cout << (valid ? "YES" : "NO") << endl;
    }
    return 0;
}

代码解析

  1. ​输入处理​​:

    • 读取数据组数 T,循环处理每组数据
    • 读取矩阵尺寸 nm 和矩阵内容
  2. ​边界初始化​​:

    • min_r/max_r/min_c/max_c:记录每个数字的行列边界(初始化为极值)
    • count:统计每个数字出现次数
  3. ​矩阵遍历​​:

    • 对每个位置 (i, j),更新对应数字的边界和计数器
    • 边界更新:通过比较当前行列值与存储的极值
  4. ​合法性验证​​:

    • 对每个出现过的数字,计算其边界矩形面积
    • 比较面积与出现次数:不等则标记非法
  5. ​结果输出​​:

    • 所有数字验证通过 → 输出 YES
    • 任意数字验证失败 → 输出 NO

实例验证

测试用例矩阵验证过程结果
合法案例00022<br>00033<br>444440: 面积=2×3=6, 次数=6<br>2: 面积=1×2=2, 次数=2<br>3: 面积=1×2=2, 次数=2<br>4: 面积=1×5=5, 次数=5YES
非法案例11122<br>11122<br>333111: 面积=3×5=15, 次数=8 → 15≠8NO
单点矩阵55: 面积=1×1=1, 次数=1YES

测试点设计

  1. ​基础功能​​:

    • 所有数字形成完整矩形(YES)
    • 数字分散在多区域(NO)
    • 矩形内部有空隙(NO)
  2. ​边界情况​​:

    • 1×1矩阵(YES)
    • 全相同数字(YES)
    • 数字0的特殊处理
  3. ​性能测试​​:

    • 最大矩阵 10×10(运行时间≤1ms)
  4. ​特殊场景​​:

    • 数字出现在边界但内部有空隙(NO)
    • 多个数字相邻但各自成矩形(YES)

注意事项

  1. ​边界初始化​​:

    • 使用 INT_MAX/INT_MIN 确保首次比较正确
    • 未出现数字直接跳过(count[d]=0
  2. ​行列计算​​:

    • 矩形高度:max_r - min_r + 1
    • 矩形宽度:max_c - min_c + 1
  3. ​字符转换​​:

    • 网格字符转数字:grid[i][j] - '0'
    • 确保输入为数字字符(0~9)

优化建议

  1. ​提前终止​​:

    if (!valid) break; // 发现非法立即终止后续检查
  2. ​合并遍历​​:

    • 若在边界更新时同步计算面积和次数,可减少一轮循环(但代码可读性降低)
  3. ​内存优化​​:

    • 用数组替代 vector(因数据规模小)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2403728.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++11 Move Constructors and Move Assignment Operators 从入门到精通

文章目录 一、引言二、基本概念2.1 右值引用&#xff08;Rvalue References&#xff09;2.2 移动语义&#xff08;Move Semantics&#xff09; 三、移动构造函数&#xff08;Move Constructors&#xff09;3.1 定义和语法3.2 示例代码3.3 使用场景 四、移动赋值运算符&#xff…

11 - ArcGIS For JavaScript -- 高程分析

这里写自定义目录标题 描述代码实现结果 描述 高程分析是地理信息系统(GIS)中的核心功能之一&#xff0c;主要涉及对地表高度数据(数字高程模型, DEM)的处理和分析。 ArcGIS For JavaScript4.32版本的发布&#xff0c;提供了Web端的针对高程分析的功能。 代码实现 <!doct…

通道注意力

一、 什么是注意力 其中注意力机制是一种让模型学会「选择性关注重要信息」的特征提取器&#xff0c;就像人类视觉会自动忽略背景&#xff0c;聚焦于图片中的主体&#xff08;如猫、汽车&#xff09;。 transformer中的叫做自注意力机制&#xff0c;他是一种自己学习自己的机制…

2048游戏的技术实现分析-完全Java和Processing版

目录 简介Processing库基础项目构建指南项目结构核心数据结构游戏核心机制图形界面实现性能优化代码详解设计模式分析测试策略总结与展望简介 2048是一款由Gabriele Cirulli开发的经典益智游戏。本文将深入分析其Java实现版本的技术细节。该实现使用了Processing库来创建图形界…

全国县域统计年鉴PDF-Excel电子版-2022年

全国县域统计年鉴PDF-Excel电子版-2022年.ziphttps://download.csdn.net/download/2401_84585615/89784662 https://download.csdn.net/download/2401_84585615/89784662 《中国县域统计年鉴》是一部全面反映中国县域社会经济发展状况的资料性年鉴。自2014年起&#xff0c;该年…

gitlab CI/CD本地部署配置

背景: 代码管理平台切换为公司本地服务器的gitlab server。为了保证commit的代码至少编译ok&#xff0c;也为了以后能拓展test cases&#xff0c;现在先搭建本地gitlab server的CI/CD基本的编译job pipeline。 配置步骤&#xff1a; 先安装gitlab-runner: curl -L "ht…

AI大模型在测试领域应用案例拆解:AI赋能的软件测试效能跃迁的四大核心引擎(顺丰科技)

导语 5月份QECon深圳大会已经结束&#xff0c;继续更新一下案例拆解&#xff0c;本期是来自顺丰科技。 文末附完整版材料获取方式。 首先来看一下这个案例的核心内容&#xff0c;涵盖了测四用例设计、CI/CD辅助、测试执行、监控预警四大方面&#xff0c;也是算大家比较熟悉的…

从零搭建uniapp项目

目录 创建uni-app项目 基础架构 安装 uni-ui 组件库 安装sass依赖 easycom配置组件自动导入 配置view等标签高亮声明 配置uni-ui组件类型声明 解决 标签 错误 关于tsconfig.json中提示报错 关于非原生标签错误&#xff08;看运气&#xff09; 安装 uview-plus 组件库…

OpenCV CUDA模块图像处理------图像融合函数blendLinear()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 该函数执行 线性融合&#xff08;加权平均&#xff09; 两个图像 img1 和 img2&#xff0c;使用对应的权重图 weights1 和 weights2。 融合公式…

图片压缩工具 | 图片生成PDF文档

OPEN-IMAGE-TINY&#xff0c;一个基于 Electron VUE3 的图片压缩工具&#xff0c;项目开源地址&#xff1a;https://github.com/0604hx/open-image-tiny ℹ️ 需求描述 上一版本发布后&#xff0c;有用户提出想要将图片转换&#xff08;或者说生成更为贴切&#xff09;PDF文档…

VSCode - VSCode 放大与缩小代码

VSCode 放大与缩小代码 1、放大 点击顶部菜单栏【查看】 -> 点击外观 -> 点击【放大】 或者&#xff0c;使用快捷键&#xff1a;Ctrl # 操作方式先按住 Ctrl 键&#xff0c;再按 键2、缩小 点击顶部菜单栏【查看】 -> 点击外观 -> 点击【缩小】 或者&#x…

11-Oracle 23ai Vector Embbeding和ONNX

Embedding &#xff08;模型嵌入&#xff09;是 AI 领域的一个核心概念 一、Embedding&#xff08;嵌入&#xff09;的含义 Embedding 是一种将 非结构化数据​&#xff08;如文本、图像、音频、视频&#xff09;转换为 数值向量的技术。 其核心是通过 嵌入模型​&#xff08;…

OpenCV 图像色彩空间转换与抠图

一、知识点: 1、色彩空间转换函数 (1)、void cvtColor( InputArray src, OutputArray dst, int code, int dstCn 0, AlgorithmHint hint cv::ALGO_HINT_DEFAULT ); (2)、将图像从一种颜色空间转换为另一种。 (3)、参数说明: src: 输入图像&#xff0c;即要进行颜…

Amazing晶焱科技:电子系统产品在多次静电放电测试后的退化案例

在我们的电子设计世界里&#xff0c;ESD&#xff08;静电放电&#xff09;问题总是让人头疼。尤其是当客户面临系统失效的困境时&#xff0c;寻找一个能够彻底解决问题的方案就变得格外重要。这一次&#xff0c;我们要谈的是一个经典案例&#xff1a;电子系统产品在多次静电放电…

C# 快速检测 PDF 是否加密,并验证正确密码

引言&#xff1a;为什么需要检测PDF加密状态&#xff1f; 在批量文档处理系统&#xff08;如 OCR 文字识别、内容提取、格式转换&#xff09;中&#xff0c;加密 PDF 无法直接操作。检测加密状态可提前筛选文件&#xff0c;避免流程因密码验证失败而中断。 本文使用 Free Spire…

华为云Flexus+DeepSeek征文| 华为云Flexus X实例单机部署Dify-LLM应用开发平台全流程指南

华为云FlexusDeepSeek征文&#xff5c; 华为云Flexus X实例单机部署Dify-LLM应用开发平台全流程指南 前言一、相关名词介绍1.1 华为云Flexus X实例介绍1.2 Dify介绍1.3 DeepSeek介绍1.4 华为云ModelArts Studio介绍 二、部署方案介绍2.1 方案介绍2.2 方案架构2.3 需要资源2.4 本…

Python: 操作 Excel折叠

💡Python 操作 Excel 折叠(分组)功能详解(openpyxl & xlsxwriter 双方案) 在处理 Excel 报表或数据分析时,我们常常希望通过 折叠(分组)功能 来提升表格的可读性和组织性。本文将详细介绍如何使用 Python 中的两个主流 Excel 操作库 —— openpyxl 和 xlsxwriter …

IBM官网新闻爬虫代码示例

通常我们使用Python编写爬虫&#xff0c;常用的库有requests&#xff08;发送HTTP请求&#xff09;和BeautifulSoup&#xff08;解析HTML&#xff09;。但这里需要注意的是&#xff0c;在爬取任何网站之前&#xff0c;务必遵守该网站的robots.txt文件和相关法律法规&#xff0c…

视觉SLAM基础补盲

3D Gaussian Splatting for Real-Time Radiance Field Rendering SOTA方法3DGS contribution传统重建基于点的渲染NeRF 基础知识补盲光栅化SFM三角化极线几何标准的双目立体视觉立体匹配理论与方法立体匹配的基本流程李群和李代数 李群和李代数的映射李代数的求导李代数解决求导…

Vue-3-前端框架Vue基础入门之VSCode开发环境配置和Tomcat部署Vue项目

文章目录 1 安装配置VSCode1.1 安装中文语言插件1.2 主题颜色1.3 禁用自动更新1.4 开启代码提示设置1.5 安装open in browser插件2 安装配置nodejs2.1 配置环境变量2.2 npm与maven的区别2.3 使用npm避坑3 创建Vue项目3.1 两种创建方式3.2 package.json3.3 安装新的依赖3.4 运行…