【LeetCode:2736. 最大和查询 | 贪心 + 二分 + 单调栈】

|-----------|
| 🚀 算法题 🚀 |

🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀
🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
🌲 作者简介:硕风和炜,CSDN-Java领域新星创作者🏆,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享💎💎💎
🌲 恭喜你发现一枚宝藏博主,赶快收入囊中吧🌻
🌲 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?🎯🎯

|-----------|
| 🚀 算法题 🚀 |

🍔 目录

    • [🚩 题目链接](#🚩 题目链接)
    • [⛲ 题目描述](#⛲ 题目描述)
    • [🌟 求解思路&实现代码&运行结果](#🌟 求解思路&实现代码&运行结果)
      • [⚡ 贪心 + 二分 + 单调栈](#⚡ 贪心 + 二分 + 单调栈)
        • [🥦 求解思路 & 实现代码](#🥦 求解思路 & 实现代码)
    • [💬 共勉](#💬 共勉)

🚩 题目链接

⛲ 题目描述

给你两个长度为 n 、下标从 0 开始的整数数组 nums1 和 nums2 ,另给你一个下标从 1 开始的二维数组 queries ,其中 queriesi = xi, yi

对于第 i 个查询,在所有满足 nums1j >= xi 且 nums2j >= yi 的下标 j (0 <= j < n) 中,找出 nums1j + nums2j 的 最大值 ,如果不存在满足条件的 j 则返回 -1 。

返回数组 answer ,其中 answeri 是第 i 个查询的答案。

示例 1:

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

输出:6,10,7

解释:

对于第 1 个查询:xi = 4 且 yi = 1 ,可以选择下标 j = 0 ,此时 nums1j >= 4 且 nums2j >= 1 。nums1j + nums2j 等于 6 ,可以证明 6 是可以获得的最大值。

对于第 2 个查询:xi = 1 且 yi = 3 ,可以选择下标 j = 2 ,此时 nums1j >= 1 且 nums2j >= 3 。nums1j + nums2j 等于 10 ,可以证明 10 是可以获得的最大值。

对于第 3 个查询:xi = 2 且 yi = 5 ,可以选择下标 j = 3 ,此时 nums1j >= 2 且 nums2j >= 5 。nums1j + nums2j 等于 7 ,可以证明 7 是可以获得的最大值。

因此,我们返回 6,10,7

示例 2:

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

输出:9,9,9

解释:对于这个示例,我们可以选择下标 j = 2 ,该下标可以满足每个查询的限制。

示例 3:

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

输出:-1

解释:示例中的查询 xi = 3 且 yi = 3 。对于每个下标 j ,都只满足 nums1j < xi 或者 nums2j < yi 。因此,不存在答案。

提示:

nums1.length == nums2.length

n == nums1.length

1 <= n <= 105

1 <= nums1i, nums2i <= 109

1 <= queries.length <= 105

queriesi.length == 2

xi == queriesi1

yi == queriesi2

1 <= xi, yi <= 109

🌟 求解思路&实现代码&运行结果


⚡ 贪心 + 二分 + 单调栈

🥦 求解思路 & 实现代码
  1. 参考题解1:官方题解:最大和查询
  2. 参考题解2:排序+单调栈上二分

【后续补充】

💬 共勉

|----------------------------------|
| 最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉! |

相关推荐
方也_arkling1 小时前
【Java-Day08】static / final / 枚举
java·开发语言
橙淮1 小时前
Spring Bean作用域与生命周期全解析
java·spring
Chengbei111 小时前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_1121 小时前
web-第一次课后作业
java·开发语言·idea
kkeeper~1 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
秋92 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本2 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
DIY源码阁2 小时前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse
wabs6663 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_876964133 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉