news 2026/6/10 14:10:21

(新卷,200分)- 探索地块建立(Java JS Python)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(新卷,200分)- 探索地块建立(Java JS Python)

(新卷,200分)- 探索地块建立(Java & JS & Python)

题目描述

给一块n*m的地块,相当于n*m的二维数组,每个元素的值表示这个小地块的发电量;

求在这块地上建立正方形的边长为c的发电站,发电量满足目标电量k的地块数量。

输入描述

第一行为四个按空格分隔的正整数,分别表示n, m , c k

后面n行整数,表示每个地块的发电量

输出描述

输出满足条件的地块数量

用例
输入2 5 2 6
1 3 4 5 8
2 3 6 7 1
输出4
说明
题目解析

本题最优解题思路是使用:二维矩阵前缀

JavaScript算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); const lines = []; let n, m, c, k; rl.on("line", (line) => { lines.push(line); if (lines.length === 1) { [n, m, c, k] = lines[0].split(" ").map(Number); } if (n && lines.length === n + 1) { const matrix = lines.slice(1).map((line) => line.split(" ").map(Number)); console.log(getResult(matrix, n, m, c, k)); lines.length = 0; } }); /** * * @param {*} matrix n*m的地块 * @param {*} n 地块行数 * @param {*} m 地块列数 * @param {*} c 正方形的发电站边长为c * @param {*} k 目标电量k */ function getResult(matrix, n, m, c, k) { const preSum = new Array(n + 1).fill(0).map(() => new Array(m + 1).fill(0)); for (let i = 1; i <= n; i++) { for (let j = 1; j <= m; j++) { preSum[i][j] = preSum[i - 1][j] + preSum[i][j - 1] - preSum[i - 1][j - 1] + matrix[i - 1][j - 1]; } } let ans = 0; for (let i = c; i <= n; i++) { for (let j = c; j <= m; j++) { const square = preSum[i][j] - (preSum[i - c][j] + preSum[i][j - c]) + preSum[i - c][j - c]; if (square >= k) ans++; } } return ans; }
Java算法源码
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); int m = sc.nextInt(); int c = sc.nextInt(); int k = sc.nextInt(); int[][] matrix = new int[n][m]; for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { matrix[i][j] = sc.nextInt(); } } System.out.println(getResult(matrix, n, m, c, k)); } /** * @param matrix n*m的地块 * @param n 地块行数 * @param m 地块列数 * @param c 正方形的发电站边长为c * @param k 目标电量k * @return 可以建设几个发电站 */ public static int getResult(int[][] matrix, int n, int m, int c, int k) { int[][] preSum = new int[n + 1][m + 1]; for (int i = 1; i <= n; i++) { for (int j = 1; j <= m; j++) { preSum[i][j] = preSum[i - 1][j] + preSum[i][j - 1] - preSum[i - 1][j - 1] + matrix[i - 1][j - 1]; } } int ans = 0; for (int i = c; i <= n; i++) { for (int j = c; j <= m; j++) { int square = preSum[i][j] - (preSum[i - c][j] + preSum[i][j - c]) + preSum[i - c][j - c]; if (square >= k) ans++; } } return ans; } }
Python算法源码
# 输入获取 n, m, c, k = map(int, input().split()) matrix = [list(map(int, input().split())) for i in range(n)] # 算法入口 def getResult(n, m, c, k, matrix): """ :param n: 调研区域的长,行数 :param m: 调研区域的宽,列数 :param c: 正方形电站的边长 :param k: 正方形电站的最低发电量 :param matrix: 调研区域每单位面积的发电量矩阵 :return: 返回调研区域有几个符合要求正方形电站 """ preSum = [[0 for j in range(m + 1)] for i in range(n + 1)] for i in range(1, n + 1): for j in range(1, m + 1): preSum[i][j] = preSum[i - 1][j] + preSum[i][j - 1] - preSum[i - 1][j - 1] + matrix[i - 1][j - 1] ans = 0 for i in range(c, n + 1): for j in range(c, m + 1): square = preSum[i][j] - (preSum[i - c][j] + preSum[i][j - c]) + preSum[i - c][j - c] if square >= k: ans += 1 return ans # 算法调用 print(getResult(n, m, c, k, matrix))
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 11:41:43

(新卷,100分)- 生日礼物(Java JS Python C)

(新卷,100分)- 生日礼物&#xff08;Java & JS & Python & C&#xff09; 题目描述 小牛的孩子生日快要到了&#xff0c;他打算给孩子买蛋糕和小礼物&#xff0c;蛋糕和小礼物各买一个&#xff0c;他的预算不超过x元。蛋糕cake和小礼物gift都有多种价位的可供选择…

作者头像 李华
网站建设 2026/6/10 1:59:28

轻量化5G实验室搭建方案:中小高校的低成本路径

人才缺口持续扩大&#xff0c;搭建专业实验室成了高校通信、物联网专业的“刚需”&#xff01;但传统方案动辄百万投入、占地超百平&#xff0c;还得专人运维&#xff0c;预算有限的中小高校根本扛不住。别慌&#xff0c;不用堆高端设备&#xff0c;不用砸巨额资金&#xff0c;…

作者头像 李华
网站建设 2026/5/28 18:45:18

计算机Java毕设实战-基于Spring Boot的保险销售员人力资源管理系统基于springboot的寿险公司人力资源管理系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/10 9:03:43

具备DI、DO、AI、AO四类IO信号的采集/输出功能以及串口、网口的通信功能,主要用于对综合测试平台及样机的功能测试提供支撑。

核控卡件综合测试平台1&#xff09;系统简介核控卡件综合测试平台具备DI、DO、AI、AO四类IO信号的采集/输出功能以及串口、网口的通信功能&#xff0c;主要用于对综合测试平台及样机的功能测试提供支撑。综合测试平台集成测试设备的对外总线接口&#xff0c;主要包括RS422、以太…

作者头像 李华
网站建设 2026/6/10 9:05:15

道路抛洒物数据集4521张VOC+YOLO格式

道路抛洒物数据集4521张VOCYOLO格式数据集格式&#xff1a;VOC格式YOLO格式压缩包内含&#xff1a;3个文件夹&#xff0c;分别存储图片、xml、txt文件JPEGImages文件夹中jpg图片总计&#xff1a;4521Annotations文件夹中xml文件总计&#xff1a;4521labels文件夹中txt文件总计&…

作者头像 李华
网站建设 2026/6/10 9:07:12

【计算机毕业设计案例】基于SpringBoot的野生动物园财务与票务一体化平台基于springboot的西安秦岭野生动物园智能化管理系统(程序+文档+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华