【华为OD机考】统计监控、需要打开多少监控器(JAVA题解——也许是全网最优)

news2024/11/18 9:31:47

前言

本人是算法小白,甚至也没有做过Leetcode。所以,我相信【同为菜鸡的我更能理解作为菜鸡的你们的痛点】。

题干

OD,B 卷 100 分题目【OD 统一考试(B 卷)】

1. 题目描述

某长方形停车场每个车位上方都有一个监控器,只有当当前车位或者前后左右四个方向任意一个车位范围停有车时,监控器才需要打开。给定某一时刻停车场的停车分布,请统计最少需要打开多少个监控器。

2. 输入描述

第一行输入m和n,表示停车场的长和宽。满足条件1 < m, n <= 20。
接下来的m行,每行包含n个整数(0或1),表示该行停车位的情况。其中0表示空位,1表示已停车。

3. 输出描述

输出最少需要打开的监控器数量

4. 示例

示例一:
输入:

3 3
0 0 0
0 1 0
0 0 0

输出:

5

示例二:
输入:

3 3
1 0 0
0 1 0
0 0 0

输出:

6

解答

说实在,我刚看到题干的时候是有点懵的,有点读不清楚题目的意思。接着我看了【示例】的输入输出之后,更加懵逼了。就算看了答案,我还是不知所云。后面拿着题干去百度,再反复思考,才理清了其中缘由,哎,其实是我自己想复杂了(有点挫败)。
我自己反思了一下,为什么我会读不清楚题目意思:

  1. 我当时读原题的时候,脑子不自觉就浮现出了停车场模型
  2. 我看原题的时候,那个博主也给了一张停车场鸟瞰图,加深了我的”刻板印象“。看着这张图,我一下子理解不了【每个车位上方都有一个监控器】的意思了(我哭死)
  3. 第一次接触机考,所以我不懂得结合输入、输出描述去理解题干
    在这里插入图片描述

解题思路

大家抛开对停车场的固有印象,也不要去看上面那张鸟瞰图,就用最原始的【面向过程】的想法去看题目。通过读题干,我们可以得到以下条件:

  1. 停车场是长方形的,并且长、宽的限制为1 < m, n <= 20(那不就是一个二维数组嘛)
  2. 每个车位上方都有一个监控器(所以,整个停车场总共有 m * n个监控器)
  3. 监控需要打开的条件:【当前停车位有车】或者【前后左右至少有一辆车】时

代码示例

public class StatisticalMonitors {

    /**
     * m、n的范围。 1< m,n <= 20
     */
    static final int MAX_COUNT = 20 + 1 + 1;

    /**
     * 【前、后、左、右】的坐标变化量
     * 用来索引当前节点【前、后、左、右】的目标位置
     */
    static final int AROUND[][] = {{1, 0}, {-1, 0}, {0, -1}, {0, 1}};

    public static void main(String[] args) {

        int row = 0, column = 0;
        int[][] parkingLot = new int[MAX_COUNT][MAX_COUNT];

        // 读入数据
        Scanner scanner = new Scanner(System.in);
        row = scanner.nextInt();
        column = scanner.nextInt();
        for (int r = 1; r <= row; r++) {
            for (int c = 1; c <= column; c++) {
                parkingLot[r][c] = scanner.nextInt();
            }
        }

        // 统计数量
        int monitorCount = 0;
        for (int r = 1; r <= row; r++) {
            for (int c = 1; c <= column; c++) {

                // 当前节点有车,直接返回
                int status = parkingLot[r][c];
                if (status == 1) {
                    monitorCount++;
                    continue;
                }

                // 没车,看看四周
                boolean b = checkAround(parkingLot, r, c);
                if (b) {
                    monitorCount++;
                }
            }
        }

        System.out.println("停车场至少需要的监控数目:" + monitorCount);
    }


    /**
     * 检查当前四周(前、后、左、右)有没有车停靠
     *
     * @return true-有车;false-没有车
     */
    private static boolean checkAround(int[][] parkingLot, int curRow, int curColumn) {
        for (int[] ints : AROUND) {
            int newRow = curRow + ints[0];
            int newColumn = curColumn + ints[1];

            int status = parkingLot[newRow][newColumn];
            if (status == 1) {
                return true;
            }
        }
        return false;
    }
}

代码解读:
整体代码都很简单,我相信看我上面的代码估计也知道啥意思了。有一些需要特别声明的点:

  1. 我新增了一个二维数组AROUND用来快速锚定当前位置的【前后左右】位置的坐标,并且为此改变了长宽条件变量MAX_COUNT的值(20 -> 20 + 1 + 1,下面我会解释为什么我要这么写)
  2. 我在读取数据的for循环区间是[1, m]而不是[0, m),这是为了方便索引(相当于把坐标整体往右下角移动了)。毕竟停车场边缘是坐标周围的坐标不好索引,需要做额外判断。这也是为什么,我要在MAX_COUNT = 20 + 1 + 1的原因。其中,20表示条件中说的长、宽范围;后面的1 + 1表示的语义如下:
    • 第一个1:整体往右下角移动
    • 第二个1:则是为了避免过多的安全判断。使当前节点周围节点可以索引。如果没有这个的话,那么在判断停车场边缘节点(即:数组边缘)的时候,为了防止数组越界,需要做额外的安全判断
      在这里插入图片描述

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

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

相关文章

[开源]基于Vue的拖拽式数据报表设计器,为简化开发提高效率而生

一、开源项目简介 Cola-Designer 是一个 基于VUE&#xff0c;实现拖拽 配置方式生成数据大屏&#xff0c;为简化开发、提高效率而生。 二、开源协议 使用GPL-2.0开源协议 三、界面展示 概览 部分截图&#xff1a; 四、功能概述 特性 0 代码 实现完全拖拽 配置式生成…

【Docker】Docker的工具实践及root概念,时间戳的概念和Docker容器安全性设置的详细讲解

作者简介&#xff1a; 辭七七&#xff0c;目前大二&#xff0c;正在学习C/C&#xff0c;Java&#xff0c;Python等 作者主页&#xff1a; 七七的个人主页 文章收录专栏&#xff1a; 七七的闲谈 欢迎大家点赞 &#x1f44d; 收藏 ⭐ 加关注哦&#xff01;&#x1f496;&#x1f…

vscode刷leetcode使用Cookie登录

1、打开vscode&#xff0c;选择扩展&#xff0c;搜索leetcode&#xff0c;选择第一个&#xff0c;带有中文力扣字样&#xff0c;安装后重启 2、选择这个小球&#xff0c;切换中文版本&#xff0c;切换后&#xff0c;会显示一个打勾 3、选择小球旁边的有箭头的小门&#xff0…

linux 安装 jsoncpp包

报错 CMake Error at CMakeLists.txt:20 (find_package): Could not find a package configuration file provided by “jsoncpp” with any of the following names: jsoncppConfig.cmake jsoncpp-config.cmake 如何安装 jsoncpp sudo aot-get install libjsoncpp-dev

dmesg 崩溃分析

dmesg 查看 segfault 各项含义 [ 7953.241716] test.out[46470]: segfault at 0 ip 00007f8f091db100 sp 00007ffe0ffa31c8 error 6 in libadd.so[7f8f091db0001000] at 引起故障的地址 ip 指令的内存地址 sp 堆栈指针地址, 即栈顶指针 error 是由三个字位组成的&#xff0c;从…

工业品商城软件java和PHP哪个好?

互联网飞速发展的今天&#xff0c;网上商城系统开发已经成为了拓展业务、提升用户体验的必备之选。 MRO工业品电商平台的概念及现状 MRO 工业品是指工厂或企业对其生产和工作设施、设备进行保养、维护、维修&#xff0c;保证其运行所需要的非生产性物料。即Maintenance 维护;…

【新书推荐】当 Python 遇到 ChatGPT —— 自动化办公落地

文章目录 当 Python 遇到 ChatGPT&#xff1a;一种强大的组合1. 文本生成2. 自动翻译3. 对话生成4. 情感分析 新书推荐《Python自动化办公应用大全&#xff08;ChatGPT版&#xff09;&#xff1a;从零开始教编程小白一键搞定烦琐工作&#xff08;上下册&#xff09;》前言内容简…

《DevOps 精要:业务视角》- 读书笔记(一)

DevOps 精要:业务视角&#xff08;一&#xff09; 第1章 什么是DevOps1.1 起源1.1.1 敏捷软件开发方法1.1.2 管理基础设施即代码1.1.3 这是必然的 1.2 定义1.3 为什么要实施DevOps&#xff1f;1.3.1 缩短市场响应时间1.3.2 减少技术债务1.3.3 消除脆弱性 1.4 历史起源1.5 常见误…

爬虫:网站三次请求获取频道内容

一、抓包 url aHR0cDovL3d3dy55amZ3LmNuLw从下图中可以看出&#xff0c;打开网页请求了三次&#xff0c;前两次在response中并不返回网页内容。 二、代码模仿第一次请求返回 <html><head><meta http-equiv"Content-Type" content"text/html; …

猜猜 JavaScript 输出:(! + [] + [] + ![]).length

一起猜 最近看到一个很有意思的题&#xff0c;直接来看&#xff0c;下面这段代码的打印结果是什么&#xff1f; console.log((! [] [] ![]).length) 猜猜看&#xff0c;你的答案是什么&#xff0c;打在评论区。 我的答案是 undefined&#xff0c;正如我的英文名 为什么呢&a…

开放式耳机的品牌有哪些?OWS不入耳开放式耳机品牌分享

开放式耳机是一种创新型的音频设备&#xff0c;与传统耳机相比&#xff0c;它有许多独特的优势。首先&#xff0c;开放式耳机不需要堵住耳道&#xff0c;因此长时间佩戴不会对听力造成损害&#xff0c;这是其最显著的优势之一。此外&#xff0c;它不需要深入入耳&#xff0c;因…

优化一对一直播实时美颜SDK性能的实践

在当今数字化社交的时代&#xff0c;直播已经成为人们分享自己生活、才艺和经验的重要方式之一。与此同时&#xff0c;美颜功能也逐渐成为许多直播平台的标配。用户期望通过直播过程中的美颜效果来展现最佳状态&#xff0c;这使得实时直播美颜SDK的性能优化变得尤为重要。本文将…

vite 项目改了node_modules下的代码不生效

解决办法&#xff1a;删除.vite文件&#xff0c;重新跑项目&#xff0c;或者跑项目的时候加上--force

java基础-第4章-面向对象(二)

一、static关键字 静态&#xff08;static&#xff09;可以修饰属性和方法。 称为静态属性&#xff08;类属性&#xff09;、静态方法&#xff08;类方法&#xff09;。 静态成员是全类所有对象共享的成员。 在全类中只有一份&#xff0c;不因创建多个对象而产生多份。 不必创…

使用tailwindcss来构建以及引入外部组件

使用tailwindcss来构建以及引入外部组件 使用tailwindcss来构建以及引入外部组件 前言构建组件 核心思想可行方案不可行方案 可行方案详解 custom css selector Functions & Directivesadd prefixadd scoped不打包 构建demo链接相关issues 前言 我们在日常的开发中&am…

cv2.split函数与cv2.merge函数

split函数用于图像BGR通道的分离 merge函数用于可将分开的图像通道合并到一起 1.split函数的使用 这是原图&#xff0c;我们使用split函数对其三个通道进行分离。 注意&#xff1a;split函数分离通道的顺序是B、G、R。 以下方法是将三个通道的值都设置为与某一个通道相同。…

AI工程化—— 如何让AI在企业多快好省的落地?

文章目录 前言内容简介读者对象专家推荐目录赠书活动 前言 作为计算机科学的一个重要领域&#xff0c;机器学习也是目前人工智能领域非常活跃的分支之一。机器学习通过分析海量数据、总结规律&#xff0c;帮助人们解决众多实际问题。随着机器学习技术的发展&#xff0c;越来越多…

asp.net+mvc+三层架构core企业员工考勤签到系统 mysql办公设备借用管理系统vue

系统中的核心员工是系统管理员&#xff0c;管理员登录后&#xff0c;通过管理员菜单来管理后台系统。主要功能有&#xff1a;管理员&#xff1a;个人中心、员工信息管理、留言板管理、系统管理、签到平台管理、签到信息管理、请假平台管理、办公设备管理、设备申请信息管理、请…

Flutter开发笔记 —— 语音消息功能实现

前言 最近在开发一款即时通讯(IM)的聊天App&#xff0c;在实现语音消息功能模块后&#xff0c;写下该文章以做记录。 注&#xff1a;本文不提供相关图片资源以及IM聊天中具体实现代码&#xff0c;单论语音功能实现思路 需求分析 比起上来直接贴代码&#xff0c;我们先来逐步…

day10_复习_数组_方法

非常重要的: 方法设计(参数,返回值,调用) 数组也重要,但是后续很少用! 是因为后期有更简单的【集合】&#xff0c;重要在于是一种思想&#xff0c;也是一种代码逻辑 关于数组: 声明创建取值,存值遍历面试|算法 --> 排序内存图(堆,栈,引用) 今天 数组工具类:Arrays数组扩容(拷…