华为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,一经查实,立即删除!

相关文章

知识图谱简单介绍

知识图谱&#xff08;Knowledge Graph&#xff09;是一种用于表达实体、概念及其之间关系的图形数据结构。它通过将现实世界中的各种概念、实体和关系以图形的形式组织起来&#xff0c;实现对知识的表示、存储和推理。知识图谱在许多领域都有广泛的应用&#xff0c;如搜索引擎、…

分享个CSDN自定义模块模板

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

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

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

代码随想录 -- 数组

文章目录 二分查找题目描述题解 移除元素题目描述题解&#xff1a;暴力解法题解&#xff1a;双指针法 有序数组的平方题目描述题解&#xff1a;暴力解法题解&#xff1a;双指针法 长度最小的子数组题目描述题解&#xff1a;暴力解法题解&#xff1a;滑动窗口&#xff08;双指针…

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

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

学习Spring的第十八天

注解方式配值声明式事务控制 直接上源码配置类 package com.itheima.config;import com.alibaba.druid.pool.DruidDataSource; import org.mybatis.spring.SqlSessionFactoryBean; import org.mybatis.spring.annotation.MapperScan; import org.springframework.beans.facto…

作业2.12

1.会出现段错误&#xff0c;因为p申请的堆区内存未返回给str&#xff0c;导致str仍然指向NULL&#xff0c;无法将"hello world"拷贝给str 2.会出现段错误&#xff0c;因为p是一个局部变量&#xff0c;函数结束时&#xff0c;p将被释放&#xff0c;不能返回它的地址&…

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

在快节奏的大学生活中&#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…

vivado Latches、Tristates、

闩锁 Vivado日志文件报告已识别闩锁的类型和大小。 推断锁存通常是HDL编码错误的结果&#xff0c;例如不完整的if或case声明。 Vivado synthesis针对以下报告示例中显示的实例发出警告。此警告允许您验证推断的Latch功能是否为预期功能。 Latches Reporting Example * Vi…

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

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

Spark中多分区写文件前可以不排序么

背景 Spark 3.5.0 目前 Spark中的实现中&#xff0c;对于多分区的写入默认会先排序&#xff0c;这是没必要的。可以设置spark.sql.maxConcurrentOutputFileWriters 为大于0来避免排序。 分析 这部分主要分为三个部分: 一个是V1Writes规则的重改; 另一个是FileFormatWriter中…

(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; 先将下面两行代码分别…

51单片机 温度传感器得数据,传到上位机

#include <reg52.h> #include <intrins.h> #define MAIN_Fosc 11059200UL //宏定义主时钟HZ #define jingzhen 11059200UL /*使用22.1184M晶体*/ // #define botelv 9600UL /*波特率定义为9600*/ unsigned char zifua; //待显示字符。volatile …

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

随着孩子步入更高的年级&#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方法带参数,其实这里应该是…

sqlserver2012 解决日志大的问题 bat脚本

要解决SQL Server 2012中事务日志过大的问题&#xff0c;你可以创建一个批处理脚本&#xff08;.bat&#xff09;来定期备份事务日志。下面是一个示例批处理脚本&#xff0c;该脚本使用SQLCMD工具来执行事务日志备份&#xff1a; echo off set "DBNAMEYourDatabaseName&qu…