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

解决leetcode第3943题递增后的数对数量

3943.递增后的数对数量

难度:困难

问题描述:

给你两个整数数组nums1和nums2,以及一个二维整数数组queries。

每个queries[i]都属于以下两种类型之一:

[1,x,y,val]:将nums2[x..y]中的每个元素都增加val。

[2,tot]:计算满足nums1[j]+nums2[k]==tot的数对(j,k)的数量。

返回一个整数数组answer,其中answer[j]表示第j个类型2查询的数对数量。

示例1:

输入:nums1=[1,2],nums2=[3,4],queries=[[2,5],[1,0,0,2],[2,5]]

输出:[2,1]

解释:

queries[0]=[2,5]:有效数对为nums1[0]+nums2[1]=1+4=5和nums1[1]+nums2[0]=2+3=5。

queries[1]=[1,0,0,2]:将nums2[0]增加2,得到nums2=[5,4]。

queries[2]=[2,5]:有效数对为nums1[0]+nums2[1]=1+4=5。

因此,answer=[2,1]。

示例2:

输入:nums1=[1,1],nums2=[2,2,3],queries=[[2,4],[1,0,1,1],[2,4]]

输出:[2,6]

解释:

queries[0]=[2,4]:有效数对为nums1[0]+nums2[2]=1+3和nums1[1]+nums2[2]=1+3。

queries[1]=[1,0,1,1]:将nums2[0]和nums2[1]各增加1,得到nums2=[3,3,3]。

queries[2]=[2,4]:nums1=[1,1]中的每个元素都可以与nums2=[3,3,3]中的每个元素配对,因为1+3=4,总共有2×3=6个数对。

因此,answer=[2,6]。

示例3:

输入:nums1=[2,5,8,4],nums2=[1,3,8],queries=[[2,9],[1,1,2,1],[2,10]]

输出:[1,0]

解释:

queries[0]=[2,9]:唯一有效数对为nums1[2]+nums2[0]=8+1=9。

queries[1]=[1,1,2,1]:将nums2[1]和nums2[2]各增加1,得到nums2=[1,4,9]。

queries[2]=[2,10]:没有数对的和为10。

因此,answer=[1,0]。

提示:

1<=nums1.length<=5

1<=nums2.length<=5*10**4

1<=nums1[i],nums2[i]<=10**5

1<=queries.length<=5*10**4

queries[i].length==2 or 4

queries[i]==[1,x,y,val],或

queries[i]==[2,tot]

0<=x<=y<nums2.length

1<=val<=10**5

1<=tot<=10**9

问题分析:

对于本题来说,从查询序列中取出每一个查询,按要求进行处理即可。对于第一种类型的查询[1,x,y,val],将nums2[x..y]中的每个元素都增加val,这通过函数increase_the_value_of_each_element_within_the_specified_range_by_val(num2,querie)实现,对于第二种类型的查询[2,tot],计算满足nums1[j]+nums2[k]==tot的数对(j,k)的数量,这通过函数get_ordered_pair_that_meets_the_conditions(num1,num2,tot)实现,在主程序中,只需要依次对查询序列queries中的每个查询,调用相应的处理函数进行处理,最后将数对数量的列表输出即解决了问题。

程序如下:

#计算满足 nums1[j] + nums2[k] == tot 的数对 (j, k)的数量并返回 def get_ordered_pair_that_meets_the_conditions(num1,num2,tot): m=len(num1) n=len(num2) a=[] for i in range(m): for j in range(n): if num1[i]+num2[j]==tot: a.append([i,j]) return len(a) #将nums2[x..y] 中的每个元素都增加val def increase_the_value_of_each_element_within_the_specified_range_by_val(num2,querie): n=len(num2) x=querie[1] y=querie[2] val=querie[3] for i in range(x,y+1): num2[i]=num2[i]+val return num2 #主程序 num1=eval(input("enter the first num1=")) num2=eval(input("enter the second num2=")) queries=eval(input("enter the second queries=")) a=[] for i in queries: b=i[0] if b==1: num2=increase_the_value_of_each_element_within_the_specified_range_by_val(num2,i) else: c=get_ordered_pair_that_meets_the_conditions(num1,num2,i[1]) a.append(c) print(a)

运行实例一

enter the first num1=[1,2,3,4]

enter the second num2=[2,3,2,2]

enter the second queries=[[1,0,2,2],[2,5],[1,2,3,1],[2,6]]

[3, 4]

运行实例二

enter the first num1=[1,1,2,2,3]

enter the second num2=[2,2,3,2,2]

enter the second queries=[[2,5],[1,1,3,1],[2,7]]

[6, 1]

http://www.gsyq.cn/news/1386550.html

相关文章:

  • 2026年当下,山东工厂取暖设备选型指南:聚焦能效与长期价值 - 2026年企业推荐榜
  • Tftpd32/Tftpd64不止是TFTP!手把手教你玩转它的DHCP和Syslog服务器功能
  • 大麦网自动化购票解决方案:技术实现与优化指南
  • DeepSeek系统设计辅助:如何在48小时内完成可审计、可回滚、可压测的AI服务架构图?
  • 【Android】AI视频剪辑-Ai剪辑视频 免费无广告
  • 2026年HR招聘偏好白皮书:这5项附加技能出现频率暴涨
  • 口碑好的本地发电机公司推荐,大型柴油发电机租赁/变压器出租租赁/应急发电机/ups不间断电源,本地发电机厂家哪家专业 - 品牌推荐师
  • 2026钢坝闸门实测评测:水利清污机、水电站清污机、河道液压钢坝、河道清污机、液压抓斗清污机、移动式清污机、耙斗式清污机选择指南 - 优质品牌商家
  • 精密零件水切割加工实测评测:水射流加工/泡沫板水切割加工/深圳水切割加工厂/瓷砖水切割加工/石材水切割加工/硅胶水切割加工/选择指南 - 优质品牌商家
  • 为什么你的Sora 2导出GIF只有256色?深度解析Pallette生成算法缺陷及3种无损色彩映射替代方案
  • 开源能源数字底座:MyEMS 在能碳数据治理与建模中的架构设计
  • 书匠策AI毕业论文一键生成?教你三分钟搞定开题到初稿的全流程!
  • 如何选择一家真正靠谱的PCB制造商?
  • impala参数之‘impala.disableHmsSync‘=‘true‘
  • 告别默认加载项!手把手教你为ArcGIS Pro插件打造专属功能区(附DAML配置详解)
  • 基于助睿BI的学生考勤画像可视化分析:精准锁定“纪律高危型“群体
  • 行为型设计模式——状态模式
  • 【CP-05】RTE运行时环境 - SWC的操作系统接口
  • SAP顾问实战:如何用ABAP函数MD_STOCK_REQUIREMENTS_LIST_API批量跑MD04数据(附完整代码)
  • 从‘邮票贴钱’到算法面试:回溯法解连续邮资问题的实战拆解与思路升华
  • 电赛备赛别慌!这份集成运放电路速查手册+Multisim仿真文件,帮你快速上手
  • 数据融合驱动的全地面起重机路面信息识别技术【附数据】
  • RT-Thread FinSH命令导出全解析:从MSH_CMD_EXPORT宏到bin文件里的秘密
  • 从LED闪烁到外设驱动:STM32 HAL库GPIO实战进阶,用CubeMx配置按键、蜂鸣器和继电器
  • 清华大学学位论文LaTeX排版终极指南:3步快速生成标准格式
  • Cadence SPB17.4元件管理器实战:批量更新原理图属性,别再傻傻手动改了
  • 2026年5月市面上冰箱清洗服务商哪家强厂家推荐榜,直冷/风冷/对开门冰箱清洗选择指南 - 海棠依旧大
  • 别再傻傻分不清:Mol、SDF、SMILES文件格式到底怎么选?
  • 揭秘生物年龄计算:BioAge工具包如何帮你量化衰老进程
  • Apifox环境变量+JavaScript实战:5分钟搞定Google Gemini API接口自动化测试