每日算法刷题Day42 7.5:leetcode前缀和3道题,用时2h

7. 3026.最大好子数组和(中等,学习)

3026. 最大好子数组和 - 力扣(LeetCode)

思想

1.给你一个长度为 n 的数组 nums 和一个 整数 k
如果 nums 的一个子数组中,第一个元素和最后一个元素 差的绝对值恰好k ,我们称这个子数组为 的。换句话说,如果子数组 nums[i..j] 满足 |nums[i] - nums[j]| == k ,那么它是一个好子数组。
请你返回 nums 子数组的 最大 和,如果没有好子数组,返回 0
2.此题|nums[i] - nums[j]| == k,既可以枚举nums[j],寻找nums[j]+knums[j]-k,所以哈希表的键为nums[j].要让s[j+1]-s[i]最大,此时s[j+1]是固定的,所以要让s[i]最小,所以哈希表的值为同一个nums[i]下最小的s[i](不包括nums[i],所以先更新哈希表再更新s)(学习如何确定的思想)

代码

c++:

class Solution {
public:long long maximumSubarraySum(vector<int>& nums, int k) {int n = nums.size();vector<long long> s(n + 1);s[0] = 0;for (int i = 0; i < n; ++i)s[i + 1] = s[i] + nums[i];long long res = LONG_MIN;map<int, long long> mp; // nums[i]-相同nums[i]下s[i]的最小值for (int j = 0; j < n; ++j) {auto it1 = mp.find(nums[j] + k);auto it2 = mp.find(nums[j] - k);if (it1 != mp.end())res = max(res, s[j + 1] - it1->second);if (it2 != mp.end())res = max(res, s[j + 1] - it2->second);auto it3 = mp.find(nums[j]);if (it3 == mp.end() || s[j] < it3->second)mp[nums[j]] = s[j];}if (res == LONG_MIN)return 0;return res;}
};

优化成一个变量,先更新哈希表再更新s

class Solution {
public:long long maximumSubarraySum(vector<int>& nums, int k) {int n = nums.size();long long s = 0;long long res = LONG_MIN;map<int, long long>mp; // nums[i]-相同nums[i]下s[i]的最小值(此时的nums[i]不包括nums[i],所以先更新哈希表再更新s)for (auto& x : nums) {auto it1 = mp.find(x + k);auto it2 = mp.find(x - k);if (it1 != mp.end())res = max(res, s + x - it1->second);if (it2 != mp.end())res = max(res, s + x - it2->second);auto it3 = mp.find(x);// 先不包括nums[i]if (it3 == mp.end() || s < it3->second)mp[x] = s;s += x;}if (res == LONG_MIN)return 0;return res;}
};
8. 1477.找两个和为目标值且不重叠的子数组(中等,动态规划,之后再做)

1477. 找两个和为目标值且不重叠的子数组 - 力扣(LeetCode)

思想
代码

c++:

9. 1546.和为目标值且不重叠的非空子数组的最大数目(中等,细节处理)

1546. 和为目标值且不重叠的非空子数组的最大数目 - 力扣(LeetCode)

思想

1.给你一个数组 nums 和一个整数 target
请你返回 非空不重叠 子数组的最大数目,且每个子数组中数字和都为 target
2.思路没有问题,对于区间[l,r),要让s[r]-s[l]=target,即s[l]=s[r]-target,所以哈希表的键为s[r],因为要不重叠,所以采取贪心思想,记录前一个区间的右端点end,哈希表的值为端点下标,此时的区间[it->second,i)

代码

c++:

class Solution {
public:int maxNonOverlapping(vector<int>& nums, int target) {int n = nums.size();int s = 0;map<int, int> mp; // s[i]-imp[0] = 0;int cnt = 0;int end = -1;for (int i = 1; i <= n; ++i) {s += nums[i - 1]; // s[i]auto it = mp.find(s - target);if (it != mp.end()) {// [,end)与[it->second,i)不重叠if (end <= it->second) {++cnt;end = i;}}mp[s] = i;}return cnt;}
};
10. 1124.表现良好的最长时间段(中等,单调栈待学习)

1124. 表现良好的最长时间段 - 力扣(LeetCode)

思想
代码

c++:

11. 3381.长度可被K整除的子数组的最大元素和(中等,学习)

3381. 长度可被 K 整除的子数组的最大元素和 - 力扣(LeetCode)

思想

1.给你一个整数数组 nums 和一个整数 k
返回 nums 中一个 非空子数组 的 最大 和,要求该子数组的长度可以 k 整除
2.区间[l,r),即(r-l)%k=0,即r%k=l%k,所以哈希表的键为j%k,要让s[r]-s[l]最大,所以哈希表的值为min(s[i]),遍历前缀和数组,先更新答案,再更新哈希表,因为是取余,所以可以开长度为k的数组,初始值为LLONG_MAX/2,防止减法溢出

代码

c++:

class Solution {
public:long long maxSubarraySum(vector<int>& nums, int k) {int n=nums.size();vector<long long> s(n+1);for(int i=0;i<n;++i)    s[i+1]=s[i]+nums[i];long long res=LLONG_MIN;vector<long long> minS(k,LLONG_MAX/2);// 遍历前缀和数组for(int j=0;j<=n;++j){int mod=j%k;res=max(res,s[j]-minS[mod]);minS[mod]=min(minS[mod],s[j]);}return res;}
};
\*map<int,long long> mp;// 遍历前缀和数组for (int j = 0; j <= n; ++j) {int mod = j % k;auto it=mp.find(mod);if(it!=mp.end()){res=max(res,s[j]-it->second);}if(it==mp.end() || s[j]<it->second) mp[mod]=s[j];}
*\

单变量s优化:

class Solution {
public:long long maxSubarraySum(vector<int>& nums, int k) {int n = nums.size();long long s = 0;long long res = LLONG_MIN;map<int, long long> mp; // 下标-值mp[k - 1] = 0;          // 前缀和第一个元素为0,下标为-1,取余k为k-1for (int j = 0; j < n; ++j) {s += nums[j];int mod = j % k;auto it = mp.find(mod);if (it != mp.end()) {res = max(res, s - it->second);}if (it == mp.end() || s < it->second)mp[mod] = s;}return res;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/89834.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/89834.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux操作系统之文件(四):文件系统(上)

前言&#xff1a; 我们前几篇文章讲了缓冲区与重定向的有关概念&#xff0c;这些设计是linux系统的核心机制&#xff0c;对系统性能、资源管理和用户操作灵活性有重要意义。 不涉及一些硬件就不可能让大家清楚地去理解文件系统&#xff0c;所以这篇文章&#xff0c;我将会从计…

java中,stream的filter和list的removeIf筛选速度比较

在 Java 里&#xff0c;Stream 的filter和 List 的removeIf筛选效率要依据具体情形来判断。 1. 操作本质有别 Stream 的 filter&#xff1a; 它是一种中间操作&#xff0c;不会立刻执行&#xff0c;而是把筛选条件记录下来。只有遇到终端操作时&#xff0c;才会开始处理元素。…

Python(28)Python循环语句指南:从语法糖到CPython字节码的底层探秘

目录 引言一、推导式家族全解析1.1 基础语法对比1.2 性能对比测试 二、CPython实现揭秘2.1 字节码层面的秘密2.2 临时变量机制 三、高级特性实现3.1 嵌套推导式优化3.2 条件表达式处理 四、性能优化指南4.1 内存使用对比4.2 执行时间优化技巧 五、最佳实践建议六、总结&#x1…

深度分析:Microsoft .NET Framework System.Random 的 C++ 复刻实现

深度分析&#xff1a;Microsoft .NET Framework Random 的 C 复刻实现 核心原理与算法结构 本实现基于 Knuth 减随机数生成器&#xff08;Subtractive Random Number Generator&#xff09;&#xff0c;是 .NET Framework 中 System.Random 的精确复刻。其核心特点包括&#x…

[论文阅读] 人工智能 | 在非CUDA硬件上运行几何学习:基于Intel Gaudi-v2 HPU的PyTorch框架移植实践

在非CUDA硬件上运行几何学习&#xff1a;基于Intel Gaudi-v2 HPU的PyTorch框架移植实践 论文标题&#xff1a;PyTorch-based Geometric Learning with Non-CUDA Processing Units: Experiences from Intel Gaudi-v2 HPUs arXiv:2507.01031 (cross-list from cs.LG) PyTorch-ba…

Python-多线程-threading

1 需求 2 接口 3 示例 4 参考资料 Python treading 模块 | 菜鸟教程

2025年- H91-Lc199-- 62.不同路径(多维动态规划)--Java版

1.题目描述 2.思路 dp含义&#xff1a;代表到当前位置的路径数 递推公式&#xff1a;dp[i][j]dp[i-1][j]dp[i][j-1] dp数组初始化&#xff0c;我们要确保第一行和第一列是有值的. dp数组的遍历顺序&#xff1a;我们需要从左往右遍历&#xff0c;从上往下遍历。并且把第一行和第…

char 不是 Java 中的 2 字节(16 位)吗? 为什么用 UTF-8 编码写入时,一个中文要占 3 个字节?

char 不是 Java 中的 2 字节&#xff08;16 位&#xff09;吗&#xff1f; 为什么用 UTF-8 编码写入时&#xff0c;一个中文要占 3 个字节&#xff1f; ✅ 一、Java 中的 char 是什么&#xff1f; Java 的 char 是一个 固定大小的 2 字节&#xff08;16 位&#xff09;类型&am…

【Elasticsearch】检索排序 分页

检索排序 & 分页 1.测试数据准备2.排序功能2.1 简单字段排序2.2 多字段排序2.3 日期排序 3.分页功能3.1 基础分页3.2 深度分页&#xff08;不推荐大数据量使用&#xff09;3.3 使用 search_after 进行高效分页 4.综合示例&#xff1a;高亮排序分页5.实践建议 1.测试数据准备…

Delta、Jackknife、Bootstrap

用班级平均身高的案例&#xff0c;展示 ​Delta、Jackknife、Bootstrap​ 的完整计算过程。 ​0. 数据准备​ ​原始数据&#xff08;4个学生的身高&#xff09;​​&#xff1a; 真实均值&#xff08;目标统计量&#xff09;​​&#xff1a; ​1. Delta 方法&#xff08;公式…

企业智脑技术架构设计:紧贴企业场景规划面向未来的发展趋势与实现路径

摘要 本文深入探讨了企业智脑技术架构的设计理念与发展趋势&#xff0c;分析了当前企业智能化转型的技术需求与挑战&#xff0c;提出了一个面向未来的企业智脑技术架构设计方案。文章从底层技术支撑、核心能力构建、应用场景适配、安全合规保障以及未来发展路径五个维度展开论…

新手向:Python方向讲解

从NASA火星任务到TikTok推荐算法&#xff0c;从自动化脚本到量子计算&#xff0c;Python用import antigravity重新定义了编程边界 一、设计哲学&#xff1a;优雅明确的编程禅学 Python之禅&#xff08;import this&#xff09;&#xff1a; 优美胜于丑陋&#xff08;Beautifu…

Chrome谷歌浏览器插件ModHeader,修改请求头,开发神器

文章目录一、介绍与下载二、使用一、介绍与下载 ModHeader顾名思义就是让我们可以自定义HTTP请求头或者是重写响应头&#xff0c;包括新增请求头/响应头或者覆盖Chrome浏览器设置的请求头的默认值&#xff0c;同时还可以根据URL Pattern来只对特定网站生效。 有条件的同学可以…

SEW:无监督预训练在语音识别中的性能-效率权衡

摘要 本文研究了自动语音识别&#xff08;ASR&#xff09;中预训练模型的性能-效率权衡问题。我们聚焦于 wav2vec 2.0&#xff0c;并形式化了多种影响模型性能和效率的架构设计。基于所有观察结果&#xff0c;我们提出了 SEW&#xff08;Squeezed and Efficient Wav2vec&#…

linux系统部署express+vue项目

一、准备阶段&#xff1a; 1、安装linux上所需要的环境&#xff1a;npm nodejs nginx pm2 //安装 npm&#xff08;Node 包管理器&#xff09; sudo apt install npm//判断是否安装成功 npm -v//安装 Node.js&#xff08;可以根据需要选择版本&#xff09; sudo apt inst…

PixiJS教程(004):点击事件交互

1.6 事件交互实现要求&#xff1a;点击宝剑&#xff0c;修改宝剑的颜色。1️⃣实现代码&#xff1a; // 为精灵添加交互事件 sprite.interactive true; sprite.on(click, () > {// 点击精灵时&#xff0c;改变精灵的颜色sprite.tint Math.random() * 0xFFFFFF; });说明&am…

创客匠人助力家庭教育IP破局:从0到1打造创始人个人品牌全攻略

一、IP定位&#xff1a;细分赛道的精准锚定与用户画像构建 在家庭教育8000亿市场规模的竞争中&#xff0c;创始人IP的差异化定位成为破局关键。创客匠人通过“标签化定位”工具&#xff0c;帮助教育者锁定垂直领域&#xff0c;如亲子沟通、青春期教育等细分赛道。以景丽霞老师…

使用坚果云扩容Zotero同步空间的简单快捷方法

本文介绍基于坚果云的WebDAV协议&#xff0c;用于文献管理软件Zotero的文件同步&#xff0c;从而实现Zotero存储空间扩容的方法。 在之前的文章Zotero文献管理软件入门使用方法&#xff1a;软件下载、文献导入、引文插入&#xff08;https://blog.csdn.net/zhebushibiaoshifu/a…

Java启动脚本

Java启动脚本 编写代码&#xff0c;然后打包 Java-1.0-SNAPSHOT.jar public class test {public static void main(String[] args) {System.out.println("Hello IDEA");} }编写运行脚本 #!/bin/sh WORKDIR$(cd $(dirname $0); pwd) cd $WORKDIRexport JAVA_OPTS"…

VSCode使用ssh远程连接阿里云

1. 终端选择 Windows使用PowerShell Ubuntu和Mac使用Terminal 2. 设置ssh 2.1. 第一台电脑 生成密钥 ssh-keygen -o -t rsa -b 4096 -C "emailexample.com" 按三次回车 查看密钥 cat ~/.ssh/id_rsa.pub 拷贝密钥&#xff0c;粘贴到服务器的密钥框中 2.2. 第…