news 2026/3/1 15:47:54

leetcode 1895(前缀和+暴力枚举)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
leetcode 1895(前缀和+暴力枚举)

1895: 最大的幻方

幻方指的是一个k x k填满整数的方格阵,且每一行、每一列以及两条对角线的和全部相等 。幻方中的整数不需要互不相同

显然,每个1 x 1的方格都是一个幻方。

思路:前缀和+暴力枚举

1.暴力检查

  • 因为m, n ≤ 50,所以最大可能的边长kmin(m,n)
  • 从大到小尝试k,找到第一个满足条件的幻方即可返回

2.优化计算

  • 我们可以预处理行前缀和和列前缀和,以便快速计算任意子矩阵的行和与列和
  • 对角线可以通过直接遍历来求和

3.算法步骤

预处理行前缀和与列前缀和,从大到小枚举边长 k
枚举子矩阵的左上角 (r,c),检查该子矩阵是否为幻方

  • 计算第一行的和作为目标值
  • 检查所有行的和是否等于目标值
  • 检查所有列的和是否等于目标值
  • 检查两条对角线的和是否等于目标值

如果找到,直接返回当前 k
如果都没找到,返回 1(因为 1×1 总是幻方)

class Solution { public: int largestMagicSquare(vector<vector<int>>& grid) { int m=grid.size(),n=grid[0].size(); vector<vector<int>> rowPrefix(m+1,vector<int>(n+1,0)); //预处理行前缀和和列前缀和 vector<vector<int>> colPrefix(m+1,vector<int>(n+1,0)); for(int i=0;i<m;i++){ for(int j=0;j<n;j++){ rowPrefix[i+1][j+1]=rowPrefix[i+1][j]+grid[i][j]; colPrefix[i+1][j+1]=colPrefix[i][j+1]+grid[i][j]; } } auto getRowsum=[&](int r,int c1,int c2){ return rowPrefix[r+1][c2+1]-rowPrefix[r+1][c1]; }; auto getColsum=[&](int c,int r1,int r2){ return colPrefix[r2+1][c+1]-colPrefix[r1][c+1]; }; for(int k=min(m,n);k>1;k--){ //从大到小枚举边长k for(int r=0;r+k<=m;r++){ for(int c=0;c+k<=n;c++){ int target=getRowsum(r,c,c+k-1); bool ok=true; for(int i=r;i<r+k;i++){ if(getRowsum(i,c,c+k-1)!=target){ ok=false; break; } } if(!ok) continue; for(int j=c;j<c+k;j++){ if(getColsum(j,r,r+k-1)!=target){ ok=false; break; } } if(!ok) continue; int diag1=0,diag2=0; for(int d=0;d<k;d++){ diag1+=grid[r+d][c+d]; diag2+=grid[r+d][c+k-1-d]; } if(diag1!=target || diag2!=target) continue; return k; } } } return 1; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/25 19:18:09

AUTOSAR架构全面讲解:初学者必备基础知识

深入理解AUTOSAR&#xff1a;从零开始掌握现代汽车电子开发的基石你有没有遇到过这样的情况&#xff1f;一个原本在A车型上运行良好的“车窗防夹”控制模块&#xff0c;移植到B车型时却需要重写大半代码——只因为换了MCU或者CAN收发器&#xff1f;又或者&#xff0c;不同供应商…

作者头像 李华
网站建设 2026/2/27 23:36:51

一键生成带情感的语音!IndexTTS 2.0保姆级使用教程

一键生成带情感的语音&#xff01;IndexTTS 2.0保姆级使用教程 在AI语音技术飞速发展的今天&#xff0c;内容创作者面临的核心挑战从未改变&#xff1a;如何让合成语音既贴合人物声线&#xff0c;又具备丰富的情感表达&#xff0c;还能精准匹配画面节奏&#xff1f;传统TTS工具…

作者头像 李华
网站建设 2026/2/26 18:03:35

科哥GLM-TTS镜像使用心得:简单高效还开源

科哥GLM-TTS镜像使用心得&#xff1a;简单高效还开源 1. 引言 在语音合成&#xff08;TTS&#xff09;技术快速发展的今天&#xff0c;如何实现高质量、低延迟且具备情感表达能力的文本转语音系统&#xff0c;成为开发者和内容创作者关注的核心问题。智谱AI推出的 GLM-TTS 模…

作者头像 李华
网站建设 2026/2/26 20:42:25

FSMN VAD音频质量检测应用:判断有效语音存在性

FSMN VAD音频质量检测应用&#xff1a;判断有效语音存在性 1. 引言 在语音处理系统中&#xff0c;准确识别音频中的有效语音片段是至关重要的预处理步骤。传统的语音活动检测&#xff08;Voice Activity Detection, VAD&#xff09;方法往往依赖于简单的能量阈值或频谱特征&a…

作者头像 李华
网站建设 2026/2/23 4:28:19

Qwen All-in-One冷备方案:灾备集群部署架构设计

Qwen All-in-One冷备方案&#xff1a;灾备集群部署架构设计 1. 引言 1.1 业务背景与灾备需求 在AI服务日益普及的今天&#xff0c;模型推理系统的稳定性直接决定了用户体验和业务连续性。尤其对于基于大语言模型&#xff08;LLM&#xff09;构建的智能服务&#xff0c;一旦主…

作者头像 李华
网站建设 2026/2/28 23:16:54

BGE-M3功能测评:密集+稀疏+多向量检索真实表现

BGE-M3功能测评&#xff1a;密集稀疏多向量检索真实表现 1. 技术背景与核心价值 在当前信息爆炸的时代&#xff0c;高效、精准的文本检索已成为搜索引擎、推荐系统和RAG&#xff08;Retrieval-Augmented Generation&#xff09;架构中的关键环节。传统单一模式的嵌入模型往往…

作者头像 李华