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

【算法题】2906. 构造乘积矩阵

题目:

给你一个下标从 0 开始、大小为 n * m 的二维整数矩阵 grid ,定义一个下标从 0 开始、大小为 n * m 的的二维矩阵 p。如果满足以下条件,则称 p 为 grid 的 乘积矩阵 :

对于每个元素 p[i][j] ,它的值等于除了 grid[i][j] 外所有元素的乘积。乘积对 12345 取余数。
返回 grid 的乘积矩阵。

示例 1:

输入:grid = [[1,2],[3,4]]
输出:[[24,12],[8,6]]
解释:p[0][0] = grid[0][1] * grid[1][0] * grid[1][1] = 2 * 3 * 4 = 24
p[0][1] = grid[0][0] * grid[1][0] * grid[1][1] = 1 * 3 * 4 = 12
p[1][0] = grid[0][0] * grid[0][1] * grid[1][1] = 1 * 2 * 4 = 8
p[1][1] = grid[0][0] * grid[0][1] * grid[1][0] = 1 * 2 * 3 = 6
所以答案是 [[24,12],[8,6]] 。
示例 2:

输入:grid = [[12345],[2],[1]]
输出:[[2],[0],[0]]
解释:p[0][0] = grid[0][1] * grid[0][2] = 2 * 1 = 2
p[0][1] = grid[0][0] * grid[0][2] = 12345 * 1 = 12345. 12345 % 12345 = 0 ,所以 p[0][1] = 0
p[0][2] = grid[0][0] * grid[0][1] = 12345 * 2 = 24690. 24690 % 12345 = 0 ,所以 p[0][2] = 0
所以答案是 [[2],[0],[0]] 。

提示:

1 <= n == grid.length <= 10^5
1 <= m == grid[i].length <= 10^5
2 <= n * m <= 10^5
1 <= grid[i][j] <= 10^9

java代码:

class Solution {public int[][] constructProductMatrix(int[][] grid) {final int MOD = 12345;int n = grid.length, m = grid[0].length;int[][] p = new int[n][m];long suf = 1; // 后缀乘积for (int i = n - 1; i >= 0; i--) {for (int j = m - 1; j >= 0; j--) {p[i][j] = (int) suf; // p[i][j] 先初始化成后缀乘积suf = suf * grid[i][j] % MOD;}}long pre = 1; // 前缀乘积for (int i = 0; i < n; i++) {for (int j = 0; j < m; j++) {p[i][j] = (int) (p[i][j] * pre % MOD); // 然后再乘上前缀乘积pre = pre * grid[i][j] % MOD;}}return p;}
}

相关文章:

【算法题】2906. 构造乘积矩阵

题目&#xff1a; 给你一个下标从 0 开始、大小为 n * m 的二维整数矩阵 grid &#xff0c;定义一个下标从 0 开始、大小为 n * m 的的二维矩阵 p。如果满足以下条件&#xff0c;则称 p 为 grid 的 乘积矩阵 &#xff1a; 对于每个元素 p[i][j] &#xff0c;它的值等于除了 g…...

机器学习基础之《回归与聚类算法(4)—逻辑回归与二分类(分类算法)》

一、什么是逻辑回归 1、逻辑回归&#xff08;Logistic Regression&#xff09;是机器学习中的一种分类模型&#xff0c;逻辑回归是一种分类算法&#xff0c;虽然名字中带有回归&#xff0c;但是它与回归之间有一定的联系。由于算法的简单和高效&#xff0c;在实际中应用非常广…...

UWB安全数据通讯STS-加密、身份认证

DW3000系列才能支持UWB安全数据通讯&#xff0c;DW1000不支持 IEEE 802.15.4a没有数据通讯安全保护机制&#xff0c;IEEE 802.15.4z中指定的扩展得到增强&#xff08;在PHY/RF级别&#xff09;&#xff1a;增添了一个重要特性“扰频时间戳序列&#xff08;STS&#xff09;”&a…...

vue3中去除eslint严格模式

vue3中去除eslint严格模式 1、全局搜索&#xff1a;extends 2、一般在package.json或者vue.config.js中&#xff0c;直接删除掉vue/standard&#xff0c;重启项目。(在package.json文件中&#xff0c;编译不允许有注释&#xff0c;所以直接删掉)...

Win10如何彻底关闭wsappx进程?

Win10如何彻底关闭wsappx进程&#xff1f;在Win10电脑中&#xff0c;用户看到了wsappx进程占用了大量的系统资源&#xff0c;所以想结束wsappx进程&#xff0c;提升电脑的运行速度。但是&#xff0c;用户们不知道彻底关闭掉wsappx进程的方法&#xff0c;那么接下来小编就给大家…...

docker 安装 sftpgo

sftpgo 简介 sftpgo 是一个功能齐全且高度可配置的 SFTP 服务器&#xff0c;具有可选的 HTTP/S、FTP/S 和 WebDAV 支持。支持多种存储后端&#xff1a;本地文件系统、加密本地文件系统、S3&#xff08;兼容&#xff09;对象存储、Google 云存储、Azure Blob 存储、SFTP。 官…...

threejs (一) 创建一个场景

引入 npm install three import * as THREE from three;const scene new THREE.Scene();或者使用bootCDN复制对应的版本连接 <script src"https://cdn.bootcdn.net/ajax/libs/three.js/0.156.1/three.js"></script>基础知识 场景、相机、渲染器 通过…...

二分查找,求方程多解

1.暴力遍历&#xff1a; 解为两位小数&#xff0c;故0.001的范围肯定可以包含&#xff08;零点存在&#xff09; 2.均分为区间长度为1的小区间&#xff08;由于两解&#xff0c;距离不小于1&#xff09;&#xff0c;一个区间最多一个解 1.防止两边端点都为解 2&…...

代码随想录算法训练营第二十九天 | 回溯算法总结

​ 代码随想录算法训练营第二十九天 | 回溯算法总结 1. 组合问题 1.1 组合问题 在77. 组合中&#xff0c;我们开始用回溯法解决第一道题目&#xff1a;组合问题。 回溯算法跟k层for循环同样是暴力解法&#xff0c;为什么用回溯呢&#xff1f;回溯法的魅力&#xff0c;用递…...

运算方法和运算电路

一、逻辑门电路 1、逻辑门电路基础总结 2、异或运算妙用 3、逻辑常用公式 二、加法器&#xff08;重点&#xff09; 1、标志位的生成原理 2、加法器总结 三、多路门选择器&#xff0c;三态门...

计算机网络篇之TCP滑动窗口

文章目录 前言概述 前言 在网络数据传输时&#xff0c;若传输的原始数据包比较大&#xff0c;会将数据包分解成多个数据包进行发送。需要对数据包确认后&#xff0c;才能发送下一个数据包。在等待确认包的这个过程浪费了大量的时间&#xff0c;不过还好TCP引入了滑动窗口的概念…...

本地安装telepresence,访问K8S集群 Mac(m1) 非管理員

kubeconfig 一&#xff0e;安装telepresence 1.安装 Telepresence Quickstart | Telepresence &#xff08;1&#xff09;brew install datawire/blackbird/telepresence 2.配置 目录kubectl 将使用默认的 kubeconfig 文件&#xff1a;$HOME/.kube/config 创建文件夹&…...

今日思考(2) — 训练机器学习模型用GPU还是NUP更有优势(基于文心一言的回答)

前言 深度学习用GPU&#xff0c;强化学习用NPU。 1.训练深度学习模型&#xff0c;强化学习模型用NPU还是GPU更有优势 在训练深度学习模型时&#xff0c;GPU相比NPU有优势。GPU拥有更高的访存速度和更高的浮点运算能力&#xff0c;因此更适合深度学习中的大量训练数据、大量矩阵…...

8.3 C++ 定义并使用类

C/C语言是一种通用的编程语言&#xff0c;具有高效、灵活和可移植等特点。C语言主要用于系统编程&#xff0c;如操作系统、编译器、数据库等&#xff1b;C语言是C语言的扩展&#xff0c;增加了面向对象编程的特性&#xff0c;适用于大型软件系统、图形用户界面、嵌入式系统等。…...

Git学习笔记——超详细

Git笔记 安装git&#xff1a; apt install git 创建版本库&#xff1a; git init 添加文件到版本库&#xff1a; git add 文件 提交文件到仓库&#xff1a; git commit -m “注释” 查看仓库当前的状态信息&#xff1a; git status 查看修改内容和之前版本的区别&am…...

Locust负载测试工具实操

本中介绍如何使用Locust为开发的服务/网站执行负载测试。 Locust 是一个开源负载测试工具&#xff0c;可以通过 Python 代码构造来定义用户行为&#xff0c;避免混乱的 UI 和臃肿的 XML 配置。 步骤 设置Locust。 在简单的 HTTP 服务上模拟基本负载测试。 准备条件 Python…...

关闭mysql,关闭redis服务

1. 关闭redis服务&#xff1a; 查询redis安装目录&#xff1a; whereis redis which redis find / -name redis 关闭redis服务&#xff1a; redis-cli -h 127.0.0.1 -p 6379 auth 输入密码 shutdown 关闭redis服务 2. 关闭mysql服务&#xff1a; 查询mysql安装目录&…...

微机原理:汇编语言语句类型与格式

文章目录 壹、语句类型1、语句分类2、常用伪代码和运算符2.1数据定义伪指令2.1.1字节定义伪指令DB&#xff08;8位&#xff09;2.1.2字定义伪指令DW&#xff08;16位&#xff09;2.1.3双字节伪指令DD2.1.4 多字节定义DF/DQ/DT&#xff08;了解&#xff09; 2.2 常用运算符2.2.1…...

iOS Flutter Engine源码调试和修改

iOS Flutter Engine源码调试和修改 1. 前提:2. 步骤&#xff1a;3. 参考资料 1. 前提: 已将成功安装deop_tools工具已经通过gclient命令同步好flutter engine源码 2. 步骤&#xff1a; 进入engine/src目录 创建flutter engine构建文件 真机文件debug模式&#xff1a; ./flu…...

Java日志系统之Log4j

目录 Log4J Log4j的简单使用 日志级别 Log4j的组件 Loggers Appenders Layout Layout格式 设置配置文件加载 配置文件解析 Log4J 是Apache下开源的日志框架 Log4j的简单使用 Testpublic void testLog4J(){Logger logger Logger.getLogger(Log4jTest.class);logger…...

IG新功能“Reels可带商品链接”上线:申请条件+内容运营全攻略

随着短视频电商的持续发展&#xff0c;Instagram 正在不断强化内容变现能力。近期&#xff0c;Meta Platforms 推出的“Reels可带商品链接”功能&#xff0c;意味着创作者可以直接在视频中完成从种草到转化的闭环。那么&#xff0c;这个新功能如何开通&#xff1f;需要满足哪些…...

ChanlunX缠论工具:3步实现股票技术分析的自动化革命

ChanlunX缠论工具&#xff1a;3步实现股票技术分析的自动化革命 【免费下载链接】ChanlunX 缠中说禅炒股缠论可视化插件 项目地址: https://gitcode.com/gh_mirrors/ch/ChanlunX 你是否还在为复杂的K线图分析而头疼&#xff1f;是否因为手工绘制缠论结构而浪费大量时间&…...

从‘灰度世界’到AI学习:深入拆解自动白平衡(AWB)算法的演进与实战选择

从‘灰度世界’到AI学习&#xff1a;深入拆解自动白平衡&#xff08;AWB&#xff09;算法的演进与实战选择 在数字图像处理领域&#xff0c;自动白平衡&#xff08;AWB&#xff09;技术如同一位隐形的色彩调音师&#xff0c;默默矫正着因环境光变化导致的色偏问题。想象一下&am…...

MQCloud消费堆积预警与处理:如何快速定位并解决消息积压问题

MQCloud消费堆积预警与处理&#xff1a;如何快速定位并解决消息积压问题 【免费下载链接】mqcloud RocketMQ企业级一站式服务平台 项目地址: https://gitcode.com/gh_mirrors/mq/mqcloud MQCloud作为RocketMQ企业级一站式服务平台&#xff0c;提供了完善的消费堆积预警与…...

为什么你的模型在STM32H7上崩溃了?——揭秘C语言ABI对齐、const段重定位与Flash执行冲突的3重隐性杀手

第一章&#xff1a;嵌入式C语言与轻量级大模型适配的底层约束全景图嵌入式系统资源受限的本质&#xff0c;决定了其与大模型技术融合并非简单移植&#xff0c;而是一场对内存、算力、确定性与工具链的系统性再平衡。C语言作为嵌入式开发的基石&#xff0c;在对接轻量级大模型&a…...

W5500网络芯片的MAC地址怎么来?三种实战方案对比:STM32唯一ID生成 vs 向IEEE申请 vs 固定地址

W5500网络芯片的MAC地址生成策略&#xff1a;从原型开发到量产的合规实践 在物联网设备开发中&#xff0c;MAC地址如同设备的网络身份证&#xff0c;其唯一性和合规性直接影响设备联网的稳定性和商业部署的合法性。以W5500为代表的嵌入式网络芯片&#xff0c;其MAC地址设置往往…...

技术深度:AB Download Manager的架构解构与高性能扩展体系

技术深度&#xff1a;AB Download Manager的架构解构与高性能扩展体系 【免费下载链接】ab-download-manager A Download Manager that speeds up your downloads 项目地址: https://gitcode.com/GitHub_Trending/ab/ab-download-manager 在现代数字内容消费时代&#x…...

如何快速使用Kemono下载器:WinUI3批量下载完整指南

如何快速使用Kemono下载器&#xff1a;WinUI3批量下载完整指南 【免费下载链接】Kemono-Downloader-GUI Kemono Downloader with WinUI3 | Kemono下载器&#xff0c;使用WinUI3构建 项目地址: https://gitcode.com/gh_mirrors/ke/Kemono-Downloader-GUI 对于需要批量下载…...

智能状态员中的行为变化与条件转移

智能状态机中的行为变化与条件转移 在人工智能与自动化系统领域&#xff0c;智能状态机&#xff08;Intelligent State Machine&#xff09;是一种关键模型&#xff0c;用于描述系统在不同状态下的行为变化以及触发状态转移的条件。通过精确控制状态间的转换逻辑&#xff0c;智…...

从QLabel超链接到桌面集成:Qt中QDesktopServices的5个实战用法(文件、邮件、网页一键打开)

从QLabel超链接到桌面集成&#xff1a;Qt中QDesktopServices的5个实战用法 在桌面应用开发中&#xff0c;系统集成能力往往决定了用户体验的上限。想象一下&#xff1a;用户点击一个链接就能直接打开默认浏览器访问网页&#xff0c;点击邮件地址就能唤起熟悉的邮件客户端&#…...