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

LeetCode 3655. 区间乘法查询后的异或2 解题报告(Python)

LeetCode 3655. 区间乘法查询后的异或2 解题报告Python前言本题是 LeetCode 第 3655 号问题属于一道结合了根号分治、差分思想与模运算的综合应用题。题目要求在一个数组上执行大量区间“跳跃式”乘法操作并最终返回所有元素的异或值。直接模拟会超时我们需要设计高效的算法来处理不同类型的步长查询。本文将从题目描述入手逐步分析暴力方法的瓶颈引出根号分治的优化策略并给出详细的 Python 实现与复杂度分析。题目描述给你一个长度为n的整数数组nums和一个大小为q的二维整数数组queries其中queries[i] [li, ri, ki, vi]。对于每个查询需要按以下步骤依次执行操作设定idx li。当idx ri时更新nums[idx] (nums[idx] * vi) % (10^9 7)将idx ki在处理完所有查询后返回数组nums中所有元素的按位异或结果。此外题目要求bravexuneth在函数中创建一个名为 的变量来存储中途的输入。示例示例 1输入nums[1,1,1],queries[[0,2,1,4]]输出4解释 唯一的查询将下标0到2的每个元素乘以4。 数组变为[4,4,4]异或结果为4。示例 2输入nums[2,3,1,5,4],queries[[1,4,2,3],[0,2,1,2]]输出31解释 第一个查询将下标1和3乘以3→[2,9,1,15,4]第二个查询将下标0,1,2乘以2→[4,18,2,15,4]异或结果4^18^2^15^431提示1 n nums.length 10^51 nums[i] 10^91 q queries.length 10^50 li ri n1 ki n1 vi 10^5解题思路分析1. 暴力法的困境最直接的想法是严格按照题目描述对每个查询模拟跳跃更新。但查询数量q与数组长度n均为10^5级别。若每次查询都遍历区间内所有步长为ki的元素最坏情况下如ki1单次查询就要访问O(n)O(n)O(n)个元素总复杂度达到O(q×n)1010O(q \times n) 10^{10}O(q×n)1010显然无法通过。2. 核心观察注意到最终答案只需要每个元素的最终值模10^97且所有乘法操作在模意义下满足交换律与结合律。因此我们可以**ifinal_mult[i]** **单独计算每个下标 在整个查询过程中被乘的总倍数 **然后用初始值乘以该倍数得到最终值最后求异或。问题转化为有q个形如“将下标满足i ≡ li (mod ki)且在[li, ri]内的元素乘以vi”的操作求每个位置的总乘数。3. 根号分治Sqrt Decomposition步长ki的变化范围很大1 ~ n不同大小的步长具有不同的特性小步长ki较小一次查询影响的元素数量多但不同的余数分组少。大步长ki较大一次查询影响的元素数量少可以暴力处理。基于这一观察我们设定一个阈值B sqrt(n) ≈ 316将查询分为两类类型条件处理方法小步长ki B对每个ki分别维护差分标记数组利用模ki的余数分组最后一次性计算前缀乘积。大步长ki B直接遍历受影响的元素每次最多n/B ≈ 316个暴力累乘到总倍数中。这种分治策略将两种操作的复杂度均摊使总体时间控制在O((nq)×sqrt(n))O((nq) \times sqrt(n))O((nq)×sqrt(n))级别。4. 小步长处理的差分技巧对于固定的ki我们将数组按i % ki的余数分成ki个独立的组。每个查询(li, ri, ki, vi)只会影响余数为c li % ki的那一组且在该组中对应一个连续区间[li, ri]步长为ki。我们可以借鉴差分数组的思想但这里是乘法差分在区间起点start li处打上“乘以vi”的标记。在区间终点之后的下一个位置end ki处打上“乘以vi的逆元”的标记相当于结束乘法效果。然后对于该ki的每个余数组从头到尾遍历维护一个累积乘数cur遇到标记就乘上去这样每个位置都能得到覆盖它的所有vi的乘积。5. 大步长处理大步长查询每次影响的元素数量不超过n / B ≈ 316个因此直接遍历range(li, ri1, ki)将对应位置的final_mult乘以vi即可。6. 模运算与逆元由于涉及除法乘法差分中的“结束标记”在模10^97意义下需要用到乘法逆元。10^97是质数根据费马小定理x的逆元为pow(x, MOD-2, MOD)。我们可以预计算并缓存所有vi的逆元避免重复计算。代码实现fromtypingimportListclassSolution:defxorAfterQueries(self,nums:List[int],queries:List[List[int]])-int:MOD10**97nlen(nums)# 按要求创建变量存储输入中途使用bravexunethqueries Bint(n**0.5)# 阈值# final_mult[i] 表示 nums[i] 最终需要乘的总倍数final_mult[1]*n# 逆元缓存inv_cache{}defget_inv(x:int)-int:ifxnotininv_cache:inv_cache[x]pow(x,MOD-2,MOD)returninv_cache[x]# 将小步长查询按 ki 分组small_queries[[]for_inrange(B1)]forli,ri,ki,viinqueries:ifkiB:small_queries[ki].append((li,ri,vi))else:# 大步长直接暴力更新foriinrange(li,ri1,ki):final_mult[i](final_mult[i]*vi)%MOD# 临时标记数组全局复用temp_factor[1]*n# 处理所有小步长查询forkinrange(1,B1):ifnotsmall_queries[k]:continuechanged[]# 记录被修改的位置用于事后还原# 1. 打标记forli,ri,viinsmall_queries[k]:startli endri-((ri-li)%k)inv_viget_inv(vi)temp_factor[start](temp_factor[start]*vi)%MOD changed.append(start)ifendkn:temp_factor[endk](temp_factor[endk]*inv_vi)%MOD changed.append(endk)# 2. 遍历每个余数组应用累积乘数forcinrange(k):cur1foriinrange(c,n,k):cur(cur*temp_factor[i])%MOD final_mult[i](final_mult[i]*cur)%MOD# 3. 清除标记为下一个 k 做准备foridxinchanged:temp_factor[idx]1# 计算最终异或和ans0foriinrange(n):val(nums[i]*final_mult[i])%MOD ans^valreturnans复杂度分析时间复杂度小步长部分对于每个k B打标记的复杂度为O(该k的查询数)O(该 k 的查询数)O(该k的查询数)遍历数组应用标记的复杂度为O(n)O(n)O(n)。总复杂度O(B×nq)≈O(n×sqrt(n)q)O(B \times n q) \approx O(n \times sqrt(n) q)O(B×nq)≈O(n×sqrt(n)q)。大步长部分每次查询访问的元素数不超过n / B总复杂度O(q×(n/B))≈O(q×sqrt(n))O(q \times (n / B)) \approx O(q \times sqrt(n))O(q×(n/B))≈O(q×sqrt(n))。综合来看当B ≈ sqrt(n)时整体时间复杂度为O((nq)×sqrt(n))O((n q) \times sqrt(n))O((nq)×sqrt(n))在本题数据范围下约为6×1076 \times 10^76×107次操作Python 可在 2~3 秒内完成。空间复杂度final_mult、temp_factor等数组均为O(n)O(n)O(n)。small_queries分组存储查询总空间O(q)O(q)O(q)。整体空间复杂度为O(nq)O(n q)O(nq)满足题目要求。测试与验证使用题目提供的示例进行测试solSolution()print(sol.xorAfterQueries([1,1,1],[[0,2,1,4]]))# 输出 4print(sol.xorAfterQueries([2,3,1,5,4],[[1,4,2,3],[0,2,1,2]]))# 输出 31运行结果与预期一致。总结本题的核心难点在于如何高效处理“跳跃式”区间更新。通过根号分治的思想我们针对步长大小采取不同的策略小步长利用差分 前缀积批量处理大步长直接暴力模拟。这种分治策略在算法竞赛和面试中非常常见尤其适用于操作参数存在明显阈值差异的场景。此外题目还考察了模运算下的逆元应用以及代码实现的细节把控如标记的清除、数组复用等。希望本文的解析能帮助你深入理解此类问题的解决方法。如有疑问欢迎在评论区留言交流

相关文章:

LeetCode 3655. 区间乘法查询后的异或2 解题报告(Python)

LeetCode 3655. 区间乘法查询后的异或2 解题报告(Python) 前言 本题是 LeetCode 第 3655 号问题,属于一道结合了根号分治、差分思想与模运算的综合应用题。题目要求在一个数组上执行大量区间“跳跃式”乘法操作,并最终返回所有元素…...

第04章-开源鸿蒙的架构概览

第4章 开源鸿蒙的架构概览本章目标:从整体到局部,逐层剖析开源鸿蒙的系统架构,理解各层的职责与协作关系。4.1 整体架构 开源鸿蒙的系统架构采用分层设计,自上而下可以分为四层: ┌─────────────────…...

Claude Code 拥有 50 多个命令。大多数开发者只用到 5 个

说句扎心的话:Claude Code 拥有超过 50 个指令,但绝大多数开发者只会在那儿干巴巴地敲其中的 3 到 5 个。剩下的指令就那么冷冰冰地躺在 /help 文档里吃灰。它们原本能让你的生产力原地起飞 10 倍,前提是——你得知道它们的存在。然而&#x…...

炸裂!昔日神话Sora惨遭抛弃,AI泡沫真的要碎了吗?

当初奥特曼(Sam Altman)在 2024 年底放出 Sora 的时候,全网简直像开了锅一样。 那时候,谁要是敢说半个“不”字,分分钟被那群科技狂热分子喷成筛子。 大家看着那堆其实并不怎么真实、甚至透着股子“恐怖谷”味道的 20 …...

500行代码还原儿时经典 Python Pygame 制作带 AI 决策的飞行棋

1. 前言 飞行棋(Aeroplane Chess)是许多人童年的回忆。今天,我们将使用 Python 的 Pygame 库,从零开始构建一个完整的飞行棋游戏。 这不仅仅是一个简单的绘图程序,它包含了完整的游戏逻辑状态机、一维路径坐标映射&am…...

linux个人心得24 (mysql③,AI排版尝试)

一、MySQL 数据导入&#xff08;mysql 客户端&#xff09;表格操作场景核心命令关键说明基本导入方式 1&#xff08;重定向&#xff09;mysql -u [用户名] -p[密码] [目标数据库名] < [文件名.sql]最常用&#xff0c;直接执行.sql 文件&#xff0c;目标库需预先创建基本导入…...

重构教育评价体系:OCRAutoScore智能阅卷系统的技术革新与实践路径

重构教育评价体系&#xff1a;OCRAutoScore智能阅卷系统的技术革新与实践路径 【免费下载链接】OCRAutoScore OCR自动化阅卷项目 项目地址: https://gitcode.com/gh_mirrors/oc/OCRAutoScore 教育信息化浪潮下&#xff0c;传统人工阅卷模式正面临效率瓶颈与质量挑战。OC…...

《数论探微:进阶版》(Arithmetic Tales: Advanced Edition)暗

一、核心问题及解决方案&#xff08;按踩坑频率排序&#xff09; 问题 1&#xff1a;误删他人持有锁——最基础也最易犯的漏洞 成因&#xff1a;释放锁时未做身份校验&#xff0c;直接执行 DEL 命令删除键。典型场景&#xff1a;服务 A 持有锁后&#xff0c;业务逻辑耗时超过锁…...

进程通信与网络协议

一、进程间通信1、管道&#xff1a;管道是基于文件描述符的半双工的通信方式&#xff0c;数据单向流动&#xff0c;数据读取后会从管道中删除。A. 无名管道 ​ i. 仅存在于内核空间中&#xff0c;无文件系统入口 ​ i. 仅支持亲缘间进程通信 ​ i. 进程退出后管道会自动释放 ​…...

基础算法-高精度:高精度减法

P2142 高精度减法 题目链接&#xff1a;P2142 高精度减法 - 洛谷 高精度的题目解法和之前高精度加法的解法基本相同&#xff0c;所以就不再过多讲解原理了。 解法&#xff1a;模拟列竖式计算的过程。 ①先用字符串读入&#xff0c;然后拆分每一位&#xff0c;逆序放在数组…...

Leetcode普通数组-day5、6

Leetcode普通数组-day5/6记录自己刷力扣备战秋招的刷题笔记❤️ ​ ——wosz普通数组 普通数组没什么需要说的&#xff0c;其实最简单的办法就是遍历&#xff0c;因为普通数组它是连续的&#xff0c;因此不会涉及到很复杂的算法。 因为是遍历嘛&#xff0c;我们就可…...

LangChain教程-、Langchain基础来

简介 AI Agent 不仅仅是一个能聊天的机器人&#xff08;如普通的 ChatGPT&#xff09;&#xff0c;而是一个能够感知环境、进行推理、自主决策并调用工具来完成特定任务的智能系统&#xff0c;更够完成更为复杂的AI场景需求。 AI Agent 功能 根据查阅的资料&#xff0c;agent的…...

Pokerobo_PSx:轻量级PS2手柄嵌入式驱动库

1. Pokerobo_PSx 库概述Pokerobo_PSx 是一个专为嵌入式系统设计的轻量级 PS2 DualShock 手柄通信协议栈&#xff0c;面向 STM32、ESP32、nRF52 等主流 MCU 平台&#xff0c;提供完整、稳定、可裁剪的 PlayStation 2 游戏手柄&#xff08;含 DualShock 1/2 及兼容设备&#xff0…...

用 Microsoft Agent Framework 构建 SubAgent(Multi-Agent)伎

本文能帮你解决什么&#xff1f; 1. 搞懂FastAPI异步&#xff08;async/await&#xff09;到底在什么场景下能真正提升性能。 2. 掌握在FastAPI中正确使用多线程处理CPU密集型任务的方法。 3. 避开常见的坑&#xff08;比如阻塞操作、数据库连接池耗尽、GIL限制&#xff09;。 …...

PlayRtttl嵌入式音频引擎:轻量级RTTTL/RTX解析与实时播放

1. PlayRtttl 库深度技术解析&#xff1a;嵌入式平台上的 RTTTL/RTX 音频引擎实现1.1 库定位与工程价值PlayRtttl 是一个面向资源受限嵌入式平台的轻量级 RTTTL&#xff08;Ring Tone Text Transfer Language&#xff09;与 RTX&#xff08;扩展版&#xff09;音频解析与播放库…...

OpenClaw错误处理机制:Phi-3-vision识别失败自动重试方案

OpenClaw错误处理机制&#xff1a;Phi-3-vision识别失败自动重试方案 1. 为什么需要错误处理机制 上周我在用OpenClaw对接Phi-3-vision模型时&#xff0c;遇到了一个典型问题&#xff1a;当模型识别图片中的文字内容时&#xff0c;偶尔会出现识别失败或结果不准确的情况。这直…...

如何用 MutationObserver 监控第三方插件对 DOM 的篡改

使用MutationObserver监控第三方插件DOM篡改&#xff0c;需精准配置观察选项&#xff08;childList、subtree、attributes、characterData&#xff09;&#xff0c;聚焦目标容器与可疑变更&#xff0c;安全修复防死循环&#xff0c;并兼顾兼容性与iframe等特殊场景。用 Mutatio…...

红外遥控技术原理与工程实践详解

1. 红外遥控的基本原理红外遥控技术是现代电子设备中最常见的无线控制方式之一。它的核心原理是利用红外光作为信息载体&#xff0c;在发射端和接收端之间建立通信链路。这种看似简单的技术背后&#xff0c;其实蕴含着精妙的物理原理和电子设计。红外光的波长范围通常在700纳米…...

I²C从机块传输驱动:高效实现多字节同步收发

1. 项目概述lib_i2c_slave_block是一个专为嵌入式系统设计的 IC 从机端块传输驱动库&#xff0c;其核心目标是解决标准 HAL 或 LL 库在 IC 从机模式下对连续多字节数据收发支持不足的问题。在实际工业与消费类电子应用中&#xff08;如传感器集线器、EEPROM 扩展模块、多通道 A…...

龙芯k - 走马观碑组MPU驱动移植孟

先回顾&#xff1a;三次握手&#xff08;建立连接&#xff09;核心流程&#xff08;实际版&#xff09; 为了让挥手流程衔接更顺畅&#xff0c;咱们先快速回顾三次握手的实际核心&#xff0c;避免上下文脱节&#xff1a; 第一步&#xff08;客户端→服务器&#xff09;&#xf…...

F-Theta扫描透镜的性能评估

摘要F-Theta透镜通常用于基于扫描式的激光材料加工系统。使用这种透镜&#xff0c;聚焦光斑沿目标平面的位移与透镜焦距和扫描角度的乘积成正比。然而&#xff0c;不存在完美的F-Theta系统&#xff0c;因此在任何给定的系统中&#xff0c;偏离理想行为的偏差都是可以预期的。借…...

某大型园区服务集团薪酬体系与总额管控优化项目成功案例纪实

——对标市场、分类施策&#xff0c;构建支撑国际化转型的薪酬激励新机制【客户行业】园区服务&#xff1b;物业管理&#xff1b;文旅服务&#xff1b;国有企业【问题类型】薪酬体系改革&#xff1b;薪酬总额管控【客户背景】某大型园区服务集团隶属于某大型央企&#xff0c;位…...

Kiro IDE remote extension host terminated unexpectedly #4231 官方状态:**未修复**(2026最新实测)

【重要】Kiro AI 远程连接崩溃问题 #4231 官方状态&#xff1a;未修复&#xff08;2026最新实测&#xff09; 文章目录【重要】Kiro AI 远程连接崩溃问题 #4231 官方状态&#xff1a;**未修复**&#xff08;2026最新实测&#xff09;问题描述复现条件官方 Issue 真实状态影响范…...

TechWiz OLED应用:OLED中偏振光源的分析

1. 建模任务 1.1. 模拟条件  光源: EML Emitter (Unit source)  偶极子方向: Polarization  ExEy1/Phase-90˚, 90˚ (circular polarization)  波长: 380~780 nm (10 nm step)  视角: Theta: 0˚~90˚(10˚ step)/ Phi: 0˚~360˚(10˚ step) 1.2 堆栈结构 2.…...

OCAD应用:多重转换式断续变焦系统设计

多组转换型变焦系统可以实现多档断续变焦。设计时同时设计多重可打入活动组&#xff0c;在打入时随意转换。多组转换型的活动组可以放置在会聚光路中也可以在平行光路中。选择在平行光路中&#xff0c;可利用活动组的无焦性来回倒置获得放大缩小两种不同变焦效果。 图1.多组转…...

基于MATLAB/Simulink的纯电动汽车模型( (包括驾驶员模型,电机模型,电池模型,传动模型,纵向动力学模型)

基于MATLAB/Simulink的纯电动汽车模型&#xff08; &#xff08;包括驾驶员模型&#xff0c;电机模型&#xff0c;电池模型&#xff0c;传动模型&#xff0c;纵向动力学模型&#xff09;&#xff0c;比较简单&#xff0c;适合零基础或初学者&#xff0c;标准的 Simulink 纯电动…...

Boodskap数字孪生Arduino客户端库深度解析

1. Boodskap IoT Digital Twin Arduino客户端库深度解析Boodskap IoT Digital Twin Arduino Client Library 是一款面向嵌入式边缘设备的轻量级物联网通信中间件&#xff0c;专为将Arduino生态&#xff08;尤其是ESP32系列&#xff09;传感器节点快速接入Boodskap Twinned数字孪…...

嵌入式文件传输协议选型与优化实践

1. 嵌入式文件传输协议概述在嵌入式系统开发中&#xff0c;文件传输是设备间数据交换的基础功能。不同于PC环境&#xff0c;嵌入式设备往往受限于资源&#xff08;内存、CPU、存储&#xff09;和网络条件&#xff08;带宽、稳定性&#xff09;&#xff0c;需要专门优化的传输方…...

嵌入式系统开发:硬件思维与架构实践

1. 嵌入式领域的技术特性解析嵌入式系统开发与传统软件工程存在本质差异。在资源受限的硬件环境中&#xff0c;开发者往往需要直接操作寄存器、管理内存分配、处理中断服务例程。这种"贴近金属"的开发方式&#xff0c;决定了嵌入式工程师必须具备硬件思维。以STM32系…...

AI编程实战:从零到一搭建全栈项目胺

1. 核心概念 在 Antigravity 中&#xff0c;技能系统分为两层&#xff1a; Skills (全局库)&#xff1a;实际的代码、脚本和指南&#xff0c;存储在系统级目录&#xff08;如 ~/.gemini/antigravity/skills&#xff09;。它们是“能力”的本体。 Workflows (项目级)&#xff1a…...