当前位置: 首页 > news >正文

用adsl做网站备案专业营销团队公司

用adsl做网站备案,专业营销团队公司,html网站开发,app官网入口100道面试必会算法-27-美团2024面试第一题-前缀和矩阵 问题解读 给定一个 n x n 的二进制矩阵,每个元素是 0 或 1。我们的任务是计算矩阵中所有边长为 k 的子矩阵中,包含特定数量 1 的情况。例如,我们希望找到所有边长为 k 的子矩阵中包含 k…

100道面试必会算法-27-美团2024面试第一题-前缀和矩阵

在这里插入图片描述

问题解读

给定一个 n x n 的二进制矩阵,每个元素是 0 或 1。我们的任务是计算矩阵中所有边长为 k 的子矩阵中,包含特定数量 1 的情况。例如,我们希望找到所有边长为 k 的子矩阵中包含 k*k/2 个 1 的子矩阵数量。

输入格式


第一行:一个整数 n,表示矩阵的大小。
接下来的 n 行:每行包含一个长度为 n 的二进制字符串,表示矩阵中的一行。

输出格式


对于每个可能的子矩阵边长 k,输出一个整数,表示边长为 k 且包含特定数量 1 的子矩阵的数量。如果 k 是奇数

计算一个大小为 n x n 的矩阵中,所有边长为 k 的子矩阵中包含特定数量的 1 的情况。通过三个主要步骤来解决这个问题:

  1. 读取输入并初始化矩阵:读取一个 n x n 的矩阵,并构建前缀和矩阵 msum
  2. 计算前缀和:通过构建前缀和矩阵,可以快速计算任何子矩阵的元素和。
  3. 检查子矩阵:对于每个可能的子矩阵,检查其是否满足条件。
什么是前缀和矩阵

前缀和矩阵是一种用于快速计算二维数组(矩阵)中子矩阵元素之和的数据结构。通过预先计算和存储每个位置的前缀和,我们可以在常数时间内计算任意子矩阵的元素和。

前缀和矩阵的构建

给定一个大小为 n x n 的矩阵 nums,我们可以构建一个前缀和矩阵 m。前缀和矩阵的每个元素 m[i][j] 表示从矩阵的左上角 (1,1) 到位置 (i,j) 的所有元素的和。其递推公式为:

m[i][j]=m[i−1][j]+m[i][j−1]−m[i−1][j−1]+nums[i][j]

在边界条件下:

  • m[i][0]m[0][j] 初始为 0,因为这些位置不可能有左上方的矩阵。

解决方案

我们将通过以下步骤来解决这个问题:

  1. 读取输入并初始化矩阵:我们将读取输入的矩阵,并使用两个矩阵 numsm 来存储矩阵元素和前缀和。
  2. 计算前缀和:前缀和矩阵 m 可以帮助我们快速计算任何子矩阵的元素和。前缀和矩阵的计算公式为: m[i][j]=m[i−1][j]+m[i][j−1]−m[i−1][j−1]+nums[i][j]
  3. 检查子矩阵:对于每个可能的子矩阵,我们通过前缀和矩阵快速计算其元素和,并检查其是否满足条件。

代码实现

import java.util.Scanner;public class Meituan {public static void main(String[] args) {Scanner input = new Scanner(System.in);int n = input.nextInt();char[] chars;int[][] m = new int[n + 1][n + 1];int[][] nums = new int[n + 1][n + 1];// 初始化矩阵和前缀和矩阵for (int i = 1; i <= n; i++) {chars = input.next().toCharArray();for (int j = 1; j <= n; j++) {nums[i][j] = chars[j - 1] - '0';m[i][j] = m[i - 1][j] + m[i][j - 1] - m[i - 1][j - 1] + nums[i][j];}}// 遍历每个可能的子矩阵边长 kfor (int k = 1; k <= n; k++) {if (k % 2 != 0) {System.out.println(0);continue;}int ans = 0;// 遍历每个可能的子矩阵for (int i = 1; i + k - 1 <= n; i++) {for (int j = 1; j + k - 1 <= n; j++) {int x = i + k - 1;int y = j + k - 1;int sum = m[x][y] - m[i - 1][y] - m[x][j - 1] + m[i - 1][j - 1];if (sum == k * k / 2) ans++;}}System.out.println(ans);}}
}

代码解析

  1. 初始化矩阵和前缀和矩阵
    • nums 用于存储输入的二进制矩阵。
    • m 用于存储前缀和矩阵,通过累加计算得到。
  2. 计算前缀和
    • 前缀和矩阵 m[i][j] 通过公式 m[i][j] = m[i-1][j] + m[i][j-1] - m[i-1][j-1] + nums[i][j] 计算得到。
    • 这样可以在常数时间内计算任何子矩阵的元素和。
  3. 遍历子矩阵
    • 对于每个可能的子矩阵,计算其元素和 sum
    • 检查该和是否等于 k*k/2,如果是,则计数器 ans 增加。

总结

任何子矩阵的元素和。
3. 遍历子矩阵

  • 对于每个可能的子矩阵,计算其元素和 sum
  • 检查该和是否等于 k*k/2,如果是,则计数器 ans 增加。

总结

通过使用前缀和矩阵,可以高效地计算出所有边长为 k 的子矩阵中包含特定数量 1 的情况。这种方法大大减少了时间复杂度,能够在合理的时间内解决较大的输入规模。

http://www.shuangfujiaoyu.com/news/23750.html

相关文章:

  • 如何修改网站标题网站关键词优化推广哪家好
  • 网站服务器免费吗深圳seo推广培训
  • 哈尔滨手机网站制作魔贝课凡seo课程好吗
  • 茂名模板建站定制网站百度指数爬虫
  • .中国域名的网站seo效果检测步骤
  • 怎样简单做网站企业网站推广模式
  • 门户网站个人可以做100个免费推广b站
  • 电商网站开发岗位职责谷歌搜索引擎入口2023
  • 网站如何做301跳转网页设计个人主页
  • 做网站官网好处全球疫情最新数据
  • 做网站推广需要什么关键词优化报价查询
  • 网站功能框架好的竞价托管公司
  • 兰州网站建设网站建设软文新闻发布网站
  • 呼和浩特公司网页设计优化网站推广教程排名
  • 免费网址怎么申请注册湖南seo优化价格
  • 制作自己盈利的网站sem竞价账户托管
  • 精美ppt模板免费下载网站海南seo
  • 做网站的技术路线免费的推文制作网站
  • dw网页设计作业成品源代码云巅seo
  • 汕头市政府门户网站市教育局频道互联网平台公司有哪些
  • 东莞倣网站seo页面优化的方法
  • 律师行业网站模板今日实时热搜
  • 网站建设进程方案三亚百度推广公司
  • 我市强化属地网站建设系统推广公司
  • 网红营销案例seo短视频加密路线
  • 杭州网站建设服务公司郑州网站推广电话
  • 建设银行找招聘网站南宁百度网站推广
  • 网站建设实训心得体会今日军事新闻最新消息
  • 中学网站模板下载温州云优化seo
  • 办理工商注册的公司南宁seo公司哪家好