华为OD机试 - 分配土地( Python C C++ JavaGo JS PHP)

题目描述

从前有个村庄,村民们在各种田地上插上小旗子,每个旗子上都标识了一个数字。现在,村民们想要找出一个包含相同数字的最小矩形区域,并将这块土地分配给对村庄做出巨大贡献的村民。我们需要找出这个矩形区域的最大面积。

输入描述

  • 第一行输入两个整数 m 和 n,分别代表土地的长和宽。
  • 接下来 m 行,每行 n 个整数,代表地图上的具体标识。其中,旗子上的数字为 1-500,未插旗子的土地用 0 标识。

输出描述

输出一个整数,代表此次分配土地时,做出贡献的村民能分配到的最大面积。

示例

在这里插入图片描述

题目解析

这个问题可以通过遍历所有可能的矩形区域来解决。对于每个数字,我们需要找到包含该数字的所有矩形区域,并计算它们的面积。然后,从这些矩形中选择面积最小的一个,作为该数字对应的最小矩形区域。最后,从所有数字对应的最小矩形区域中选择面积最大的一个,作为最终的答案。

然而,这种方法的时间复杂度非常高,因为需要遍历所有可能的矩形区域。在实际应用中,我们可以使用一种更高效的方法来解决这个问题。

观察题目,我们可以发现,对于每个数字,我们只需要找到包含该数字的所有连通区域,并计算它们的面积。然后,从这些连通区域中选择面积最小的一个,作为该数字对应的最小矩形区域。这样,我们就可以将问题转化为寻找连通区域的问题。

为了找到包含某个数字的所有连通区域,我们可以使用深度优先搜索(DFS)或广度优先搜索(BFS)算法。从每个包含该数字的点开始搜索,直到找到所有与该点连通的点。然后,计算这些点的最小矩形区域,并更新该数字对应的最小矩形区域。

最后,从所有数字对应的最小矩形区域中选择面积最大的一个作为最终的答案。

  1. 创建一个二维数组来存储地图上的标识。
  2. 对于每个数字(1-500),使用 DFS 或 BFS 找到包含该数字的所有连通区域,并计算它们的面积。可以使用一个辅助数组来标记已经访问过的点。
  3. 对于每个连通区域,计算其最小矩形区域的面积。可以通过找到连通区域中所有点的最小和最大坐标来实现。
  4. 更新该数字对应的最小矩形区域的面积。可以使用一个哈希表来存储每个数字对应的最小矩形区域的面积。
  5. 从哈希表中选择面积最大的值作为最终的答案。
  6. 输出答案。

Python代码实现

def dfs(grid, row, col, num, visited):# 检查边界条件和访问状态if row < 0 or row >= len(grid) or col < 0 or col >= len(grid[0]) or visited[row][col] or grid[row][col] != num:return 0# 标记当前位置为已访问visited[row][col] = True# 向四个方向递归搜索,并计算连通区域的面积area = 1directions = [(0, 1), (0, -1), (1, 0), (-1, 0)]for dx, dy in directions:area += dfs(grid, row + dx, col + dy, num, visited)return areadef find_min_rectangle_area(grid):if not grid or not grid[0]:return 0m, n = len(grid), len(grid[0])visited = [[False] * n for _ in range(m)]min_area = float('inf')  # 初始化为无穷大# 遍历所有数字和对应的位置for i in range(m):for j in range(n):if not visited[i][j] and grid[i][j] != 0:num = grid[i][j]area = dfs(grid, i, j, num, visited)# 找到最小矩形面积min_area = min(min_area, area)# 如果没有找到有效的矩形区域,返回0return min_area if min_area != float('inf') else 0# 示例输入
m, n = 4, 4
grid = [[1, 1, 1, 1],[1, 0, 0, 1],[1, 0, 1, 1],[1, 1, 1, 1]
]# 计算并输出最小矩形面积
print(find_min_rectangle_area(grid))  # 输出应为4,因为最小矩形区域是2x2的

C++代码实现

#include <iostream>  
#include <vector>  
#include <algorithm>  using namespace std;  // 方向数组,用于DFS中的四个方向移动  
const int dx[] = {-1, 1, 0, 0};  
const int dy[] = {0, 0, -1, 1};  // DFS函数,计算以(row, col)为起点的连通区域面积  
int dfs(vector<vector<int>>& grid, vector<vector<bool>>& visited, int row, int col, int num) {  if (row < 0 || row >= grid.size() || col < 0 || col >= grid[0].size() ||  visited[row][col] || grid[row][col] != num) {  return 0;  }  visited[row][col] = true;  int area = 1;  for (int i = 0; i < 4; ++i) {  area += dfs(grid, visited, row + dx[i], col + dy[i], num);  }  return area;  
}  // 主函数,寻找最小矩形区域的面积  
int findMinRectangleArea(vector<vector<int>>& grid) {  if (grid.empty() || grid[0].empty()) return 0;  int m = grid.size();  int n = grid[0].size();  int minArea = INT_MAX;  // 对每个非零数字进行遍历  for (int i = 0; i < m; ++i) {  for (int j = 0; j < n; ++j) {  if (grid[i][j] != 0) {  vector<vector<bool>> visited(m, vector<bool>(n, false));  int num = grid[i][j];  int area = dfs(grid, visited, i, j, num);  minArea = min(minArea, area);  }  }  }  // 如果没有找到有效的矩形区域,返回0  return (minArea == INT_MAX) ? 0 : minArea;  
}  int main() {  int m, n;  cin >> m >> n;  vector<vector<int>> grid(m, vector<int>(n));  for (int i = 0; i < m; ++i) {  for (int j = 0; j < n; ++j) {  cin >> grid[i][j];  }  }  int result = findMinRectangleArea(grid);  cout << "The minimum rectangle area is: " << result << endl;  return 0;  
}

C代码实现

#include <stdio.h>
#include <stdlib.h>using namespace std;const int dx[] = {-1, 1, 0, 0};
const int dy[] = {0, 0, -1, 1};int dfs(vector<vector<int>>& grid, vector<vector<bool>>& visited, int row, int col, int num) {if (row < 0 || row >= grid.size() || col < 0 || col >= grid[0].size() ||visited[row][col] || grid[row][col] != num) {return 0;}visited[row][col] = true;int area = 1;for (int i = 0; i < 4; ++i) {area += dfs(grid, visited, row + dx[i], col + dy[i], num);}return area;
}int findMinRectangleArea(vector<vector<int>>& grid) {if (grid.empty() || grid[0].empty()) return 0;int m = grid.size();int n = grid[0].size();int minArea = INT_MAX;for (int i = 0; i < m; ++i) {for (int j = 0; j < n; ++j) {if (grid[i][j] != 0) {vector<vector<bool>> visited(m, vector<bool>(n, false));int num = grid[i][j];int area = dfs(grid, visited, i, j, num);minArea = min(minArea, area);}}}return (minArea == INT_MAX) ? 0 : minArea;
}int main() {int m, n;scanf("%d %d", &m, &n);vector<vector<int>> grid(m, vector<int>(n));for (int i = 0; i < m; ++i) {for (int j = 0; j < n; ++j) {scanf("%d", &grid[i][j]);}}int result = findMinRectangleArea(grid);printf("The minimum rectangle area is: %d\n", result);return 0;
}

Java代码实现

import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);System.out.println("Enter the number of rows and columns:");int m = scanner.nextInt();int n = scanner.nextInt();int[][] grid = new int[m][n];for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {grid[i][j] = scanner.nextInt();}}int result = findMinRectangleArea(grid);System.out.println("The minimum rectangle area is: " + result);}public static int findMinRectangleArea(int[][] grid) {if (grid.length == 0 || grid[0].length == 0) {return 0;}int m = grid.length;int n = grid[0].length;int minArea = Integer.MAX_VALUE;for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {if (grid[i][j] != 0) {boolean[][] visited = new boolean[m][n];int num = grid[i][j];int area = dfs(grid, visited, i, j, num);minArea = Math.min(minArea, area);}}}return minArea == Integer.MAX_VALUE ? 0 : minArea;}public static int dfs(int[][] grid, boolean[][] visited, int row, int col, int num) {if (row < 0 || row >= grid.length || col < 0 || col >= grid[0].length ||visited[row][col] || grid[row][col] != num) {return 0;}visited[row][col] = true;int area = 1;for (int i = 0; i < 4; i++) {area += dfs(grid, visited, row + dx[i], col + dy[i], num);}return area;}private static int[] dx = {-1, 1, 0, 0};private static int[] dy = {0, 0, -1, 1};
}

Go代码实现

package mainimport ("container/heap""fmt""math/rand""strconv""time"
)const (dx = [4]int{-1, 1, 0, 0}dy = [4]int{0, 0, -1, 1}
)func dfs(grid [][]int, visited [][]bool, row, col, num int) int {if row < 0 || row >= len(grid) || col < 0 || col >= len(grid[0]) ||visited[row][col] || grid[row][col] != num {return 0}visited[row][col] = truearea := 1for i := 0; i < 4; i++ {area += dfs(grid, visited, row+dx[i], col+dy[i], num)}return area
}func findMinRectangleArea(grid [][]int) int {m, n := len(grid), len(grid[0])minArea := 0for i := 0; i < m; i++ {for j := 0; j < n; j++ {if grid[i][j] != 0 {visited := make([][]bool, m)for k := range visited {visited[k] = make([]bool, n)}num := grid[i][j]area := dfs(grid, visited, i, j, num)if minArea == 0 || area < minArea {minArea = area}}}}if minArea == 0 {return 0}return minArea
}func main() {var m, n intfmt.Scan(&m, &n)grid := make([][]int, m)for i := range grid {grid[i] = make([]int, n)}for i := 0; i < m; i++ {for j := 0; j < n; j++ {fmt.Scan(&grid[i][j])}}result := findMinRectangleArea(grid)fmt.Println("The minimum rectangle area is:", result)
}

PHP代码实现

<?phpfunction findMinRectangleArea($grid) {$m = count($grid);$n = count($grid[0]);$minArea = INT_MAX;for ($i = 0; $i < $m; $i++) {for ($j = 0; $j < $n; $j++) {if ($grid[$i][$j] != 0) {$visited = array_fill(0, $m, array_fill(0, $n, false));$num = $grid[$i][$j];$area = $this->dfs($grid, $visited, $i, $j, $num);$minArea = min($minArea, $area);}}}return $minArea == INT_MAX ? 0 : $minArea;
}private function dfs($grid, $visited, $row, $col, $num) {if ($row < 0 || $row >= count($grid) || $col < 0 || $col >= count($grid[0]) ||$visited[$row][$col] || $grid[$row][$col] != $num) {return 0;}$visited[$row][$col] = true;$area = 1;for ($i = 0; $i < 4; $i++) {$area += $this->dfs($grid, $visited, $row + $this->dx[$i], $col + $this->dy[$i], $num);}return $area;
}private $dx = array(-1, 1, 0, 0);
private $dy = array(0, 0, -1, 1);$grid = array(// 示例数据array(1, 1, 1, 0, 0),array(1, 1, 1, 0, 0),array(1, 1, 1, 0, 0),array(0, 0, 0, 0, 0),array(0, 0, 0, 0, 0)
);echo "Enter the number of rows and columns:" . PHP_EOL;
$m = intval(fgets(STDIN));
$n = intval(fgets(STDIN));
$grid = array_fill(0, $m, array_fill(0, $n, 0));
for ($i = 0; $i < $m; $i++) {for ($j = 0; $j < $n; $j++) {$grid[$i][$j] = intval(fgets(STDIN));}
}$result = findMinRectangleArea($grid);
echo "The minimum rectangle area is: " . $result . PHP_EOL;

JS代码实现

const { Your_function } = require(‘Your_script’);function main() {const scanner = require('scanner');console.log('Enter the number of rows and columns:');const m = scanner.nextInt();const n = scanner.nextInt();const grid = new Array(m).fill(0).map(() => new Array(n).fill(0));for (let i = 0; i < m; i++) {for (let j = 0; j < n; j++) {grid[i][j] = scanner.nextInt();}}const result = findMinRectangleArea(grid);console.log('The minimum rectangle area is: ' + result);
}function findMinRectangleArea(grid) {if (grid.length === 0 || grid[0].length === 0) {return 0;}const m = grid.length;const n = grid[0].length;let minArea = Infinity;for (let i = 0; i < m; i++) {for (let j = 0; j < n; j++) {if (grid[i][j] !== 0) {const visited = new Array(m).fill(0).map(() => new Array(n).fill(false));const num = grid[i][j];const area = dfs(grid, visited, i, j, num);minArea = Math.min(minArea, area);}}}return minArea === Infinity ? 0 : minArea;
}function dfs(grid, visited, row, col, num) {if (row < 0 || row >= grid.length || col < 0 || col >= grid[0].length ||visited[row][col] || grid[row][col] !== num) {return 0;}visited[row][col] = true;let area = 1;for (let i = 0; i < 4; i++) {area += dfs(grid, visited, row + dx[i], col + dy[i], num);}return area;
}const dx = [-1, 1, 0, 0];
const dy = [0, 0, -1, 1];

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

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

相关文章

分享个CSDN自定义模块模板

在开了会员或升级为博客专家后&#xff0c;才有这个自定义模块的权限 当然这也是为了有很多粉丝的博主更方便的推广一些业务场景展示的橱窗 自定义模块管理 下面就列下我使用的自定义模块相关的代码 <marquee><b><font color"#8A2BE2">不</…

[WinForm开源]概率计算器 - Genshin Impact(V1.0)

创作目的&#xff1a;为方便旅行者估算自己拥有的纠缠之缘能否达到自己的目的&#xff0c;作者使用C#开发了一款小型软件供旅行者参考使用。 创作说明&#xff1a;此软件所涉及到的一切概率与规则完全按照游戏《原神》(V4.4.0)内公示的概率与规则&#xff08;包括保底机制&…

猫头虎分享已解决Bug || DNS解析问题(DNS Resolution Issue):DNSLookupFailure, DNSResolveError

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

大学生必备搜题软件推荐?找题不再难!好用的大学搜题工具推荐 #媒体#职场发展

在快节奏的大学生活中&#xff0c;合理利用这些日常学习工具&#xff0c;能够让你事半功倍&#xff0c;提高学习效率。 1.茱莉亚公开课 茱莉亚公开课APP不是一款针对所有人的应用&#xff0c;是针对对艺术有特殊爱好和艺术领域的人 茱莉亚音乐学院里面都是世界著名的茱莉亚音…

Vulhub kali 环境安装教程

进入 root 权限 sudo su 更新软件 apt-get update 安装 HTTPS 协议和 CA 证书 apt-get install -y apt-transport-https ca-certificates 安装 docker apt install docker.io 查看 docker 是否安装完成 docker -v 安装 pip apt-get install python3-pip 安装 docker-compose do…

Linux第57步_“linux系统镜像”和“根文件系统”重新打包小结

实时总结是很重要的&#xff0c;时间久了&#xff0c;可能会遗忘。下面是“linux系统镜像”和“根文件系统”重新打包小结。 1、linux系统镜像重新打包 在第1次完成linux系统镜像打包后&#xff0c;再重新打包就很容易了 将“bootfs”重新打包 准备打包文件: 输入“cd /ho…

(10)Hive的相关概念——文件格式和数据压缩

目录 一、文件格式 1.1 列式存储和行式存储 1.1.1 行存储的特点 1.1.2 列存储的特点 1.2 TextFile 1.3 SequenceFile 1.4 Parquet 1.5 ORC 二、数据压缩 2.1 数据压缩-概述 2.1.1 压缩的优点 2.1.2 压缩的缺点 2.2 Hive中压缩配置 2.2.1 开启Map输出阶段压缩&…

MySQL篇之回表查询

一、聚集索引 将数据存储与索引放到了一块&#xff0c;索引结构的叶子节点保存了行数据。特点&#xff1a;必须有,而且只有一个。 聚集索引选取规则: 1. 如果存在主键&#xff0c;主键索引就是聚集索引。 2. 如果不存在主键&#xff0c;将使用第一个唯一&#xff08;UNIQUE&am…

Linux环境中的git

目录 1.要使用git&#xff0c;首先要安装git 2.首次使用git需要做的操作 3.git操作 1.要使用git&#xff0c;首先要安装git 指令&#xff1a;sudo yum install -y git 2.首次使用git需要做的操作 在gitee网页&#xff0c;在你的仓库中找到&#xff1a; 先将下面两行代码分别…

高中生护眼台灯怎么选?教育部认可护眼灯品牌

随着孩子步入更高的年级&#xff0c;学业压力也会越来越繁重&#xff0c;随之带来的也是更长时间的用眼和高近视率。众所周知&#xff0c;高中是孩子学业最繁忙的一段时期&#xff0c;同时也是青少年近视的重灾区&#xff0c;不少学生因为每天过度用眼&#xff0c;再加上缺少户…

【Cocos入门】物理系统(物理碰撞)

物理碰撞 物理引擎默认是关闭状态以节省资源开销。开启方法和之前的普通碰撞类似&#xff1a;cc.director.getPhysicsManager().enabled true但有一个区别&#xff0c;物理引擎的开启必须放在onLoad函数内运行&#xff0c;否则不生效。 物理碰撞组件也同样具有碰撞回调函数。…

day14笔记(多态)

多态 自己写多态演示遇见两个问题 1.在类里写show方法时犹豫要不要写参数,其实不用写参数也可以获取到类的信息 public void show(){//括号里面写参数吗System.out.println(getName()", "getAge());} 2.在测试类里面写方法时,写了一个show方法带参数,其实这里应该是…

【网站项目】229企业员工薪酬关系系统

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

【计算机是如何工作的】编程语言是如何与CPU指令对应起来

编程语⾔&#xff08;Program Language&#xff09; 程序&#xff08;Program&#xff09;早期编程编程语⾔发展操作系统&#xff08;Operating System&#xff09;什么是进程/任务&#xff08;Process/Task&#xff09;进程控制块抽象(PCB Process Control Block)CPU 分配⸺进…

[OPEN SQL] 新增数据

INSERT语句用于数据的新增操作 本次操作使用的数据库表为SCUSTOM&#xff0c;其字段内容如下所示 航班用户(SCUSTOM) 该数据库表中的部分值如下所示 1.插入单条数据 语法格式 INSERT <dbtab> FROM <wa>. INSERT INTO <dbtab> VALUES <wa>. INSERT &…

【Cocos入门】物理检测

目录 一、物理检测的概念二、点测试三、矩形测试四、射线测试 一、物理检测的概念 CoCos中&#xff0c;物理检测也是物理系统的一部分&#xff0c;它不是用于检测物体的物理特性的&#xff0c;而是用来查询物体的(比如某个地方是否存在物理碰撞体)。其又分成&#xff1a;点检测…

编程和计算机基础

编程 编程&#xff1a;就是让计算机为解决某个问题而使用某种程序设计语言编写程序代码&#xff0c;并最终得到结果的过程。 计算机程序&#xff1a;是计算机所执行的一系列的指令集合&#xff0c;而程序全部都是用我们所掌握的语言来编写的&#xff0c;所以人们控制计算机一…

云备份项目:在云端保护您的数据【一、初识】

桃李不言&#xff0c;下自成蹊 文章目录 项目简介项目设计方案服务端功能划分客户端功能划分 项目环境搭建环境准备第三方库JsonCppbundle数据压缩库httplib 总结 ☘️项目源代码&#xff1a;云备份 ☘️云备份专栏&#xff1a;云备份 项目简介 云备份系统是一个自动化的备份解…

Spring 事务原理总结四

作为一名认知有限的中国人&#xff0c;我对年的喜爱&#xff0c;胜过其他一切&#xff0c;因为它给了我拒绝一切的合理理由。每到这个时候&#xff0c;我都会用各种理由来为自己的不作为开脱&#xff0c;今年亦是如此。看着频频发出警报的假期余额&#xff0c;我内心的焦躁变得…

【优化数学模型】1. 基于Python的线性规划问题求解

【优化数学模型】1. 基于Python的线性规划问题求解 一、线性规划问题1.概述2.三要素 二、示例&#xff1a;药厂生产问题三、使用 Python 绘图求解线性规划问题1.绘制约束条件2.绘制可行域3.绘制目标函数4.绘制最优解 四、使用 scipy.optimize 软件包求解线性规划问题1.导入库2.…