枚举中间

对于三个或者四个变量的问题,枚举中间的变量往往更好算。
为什么?比如问题有三个下标,需要满足 0≤i<j<k<n,对比一下:
枚举 i,后续计算中还需保证 j<k。
枚举 j,那么 i 和 k 自动被 j 隔开,互相独立,后续计算中无需关心 i 和 k 的位置关系。
所以枚举中间的变量更简单。

1.套路
class Solution {
public:int minimumSum(vector<int>& nums) {int n=nums.size();// 后缀数组维护k的最小值vector<int> sufMin(n,0);sufMin[n-1]=nums[n-1];for(int i=n-2;i>=0;--i){sufMin[i]=min(sufMin[i+1],nums[i]);}int preMin=nums[0],res=INT_MAX;// 枚举j,注意j范围[1,n-1)for(int j=1;j+1<n;++j){if(nums[j]>preMin && nums[j]>sufMin[j+1])   res=min(res,preMin+nums[j]+sufMin[j+1]);// 单变量维护i的最小值preMin=min(preMin,nums[j]);}if(res==INT_MAX)    return -1;else    return res;}
};
2.题目描述

1.给你一个下标从 0 开始的整数数组 nums 。
如果下标三元组 (i, j, k) 满足下述全部条件(题目条件),则认为它是一个 山形三元组 :

  • i < j < k
  • nums[i] < nums[j] 且 nums[k] < nums[j]
    请你找出 nums 中 元素和最小 的山形三元组,并返回其 元素和(答案) 。如果不存在满足条件的三元组,返回 -1 。
    2.给你一个整数数组 nums
    特殊三元组 **定义为(题目条件)**满足以下条件的下标三元组 (i, j, k)
  • 0 <= i < j < k < n,其中 n = nums.length
  • nums[i] == nums[j] * 2
  • nums[k] == nums[j] * 2
    返回数组中 特殊三元组的总数(答案)
    由于答案可能非常大,请返回结果对 109 + 7 取余数后的值。
3.学习经验

1.i的维护跟枚举右,维护左一样,可以随着j的枚举而动态更新,所以可以用单变量或者map(更新答案后加入j)实现,但k的维护需要在枚举j之前完成,通常要借助数组和map(更新答案前删去j),无法用一个变量实现

1. 2909.元素和最小的山形三元组II(中等,学习,前后缀最小值维护)

2909. 元素和最小的山形三元组 II - 力扣(LeetCode)

思想

1.给你一个下标从 0 开始的整数数组 nums 。
如果下标三元组 (i, j, k) 满足下述全部条件,则认为它是一个 山形三元组 :

  • i < j < k
  • nums[i] < nums[j] 且 nums[k] < nums[j]
    请你找出 nums 中 元素和最小 的山形三元组,并返回其 元素和 。如果不存在满足条件的三元组,返回 -1 。
    2.这题三个变量,所以要枚举中间变量j,而nums[i]的最小值维护可以跟着j的枚举一起更新,所以只需要一个变量preMin即可,但是nums[j+1]-nums[n-1]的最小值无法只用一个变量维护,需要提前递推算出后缀最小值(类似于前缀和),令 s u f M i n [ i ] sufMin[i] sufMin[i]表示[i,n)的最小值,所以得到递推公式:
    s u f M i n [ i ] = m i n ( s u f M i n ( i + 1 ) , n u m s [ i ] ) sufMin[i]=min(sufMin(i+1),nums[i]) sufMin[i]=min(sufMin(i+1),nums[i]),从后向前更新,在枚举j前维护即可
    3.所以满足山形条件为:
nums[j]>preMin && nums[j]>sufMin[j+1]

更新答案:

res=min(res,pre+nums[j]+sufMin[j+1])

更新preMin:

preMin=min(preMin,nums[j])
代码

c++:

class Solution {
public:int minimumSum(vector<int>& nums) {int n=nums.size();// 后缀数组维护k的最小值vector<int> sufMin(n,0);sufMin[n-1]=nums[n-1];for(int i=n-2;i>=0;--i){sufMin[i]=min(sufMin[i+1],nums[i]);}int preMin=nums[0],res=INT_MAX;// 枚举j,注意j范围[1,n-1)for(int j=1;j+1<n;++j){if(nums[j]>preMin && nums[j]>sufMin[j+1])   res=min(res,preMin+nums[j]+sufMin[j+1]);// 单变量维护i的最小值preMin=min(preMin,nums[j]);}if(res==INT_MAX)    return -1;else    return res;}
};
2. 3583.统计特殊三元组(中等)

3583. 统计特殊三元组 - 力扣(LeetCode)

思想

1.给你一个整数数组 nums
特殊三元组 定义为满足以下条件的下标三元组 (i, j, k)

  • 0 <= i < j < k < n,其中 n = nums.length
  • nums[i] == nums[j] * 2
  • nums[k] == nums[j] * 2
    返回数组中 特殊三元组 的总数。
    由于答案可能非常大,请返回结果对 109 + 7 取余数后的值。
    2.学习1. 2909.元素和最小的山形三元组II的思想,本题需要知道[0,j-1]nums[j]*2的个数和[j+1,n)nums[j]*2的个数,前者就是正常的枚举右,维护左会用到的map技巧,后者也可以利用这个思想,不过我的代码复杂了,还开了一个数组来计算,可以直接用map,再计算答案前先把nums[j]减去即可,而前者是计算答案后要把nums[j]加上,因为枚举j,所以i和k相互独立,用乘法原理相乘即可
代码

c++:
我的代码

class Solution {
public:int specialTriplets(vector<int>& nums) {const int mod = 1e9 + 7;int n = nums.size();map<long long, long long> suf;  // 维护k,数-个数vector<long long> sufCnt(n, 0); // 维护k,个数map<long long, long long> pre;  // 维护i,数-个数for (int i = n - 1; i >= 0; --i) {sufCnt[i] = suf[2 * nums[i]];++suf[nums[i]];}long long res = 0;++pre[nums[0]];for (int j = 1; j + 1 < n; ++j) {res = (res + pre[nums[j] * 2] * sufCnt[j]) % mod;++pre[nums[j]];}return res;}
};

优化:

class Solution {
public:int specialTriplets(vector<int>& nums) {const int mod = 1e9 + 7;int n = nums.size();map<long long, long long> suf; // 维护k,数-个数map<long long, long long> pre; // 维护i,数-个数// 跟下面j的范围一样for (int j = 1; j < n; ++j)++suf[nums[j]];long long res = 0;++pre[nums[0]];for (int j = 1; j + 1 < n; ++j) {--suf[nums[j]];res = (res + pre[nums[j] * 2] * suf[nums[j] * 2]) % mod;++pre[nums[j]];}return res;}
};

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

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

相关文章

【教学类-18-06】20250623蒙德里安黑白七款合并WORD(500张、无学号)

背景需要 客户买了蒙德里安黑白格子7种尺寸,但是不需要学号方块,并指定要WORD 设计思路 【教学类-18-05】20241118正方形手工纸(蒙德里安-风格派-红黄蓝黑白)-CSDN博客文章浏览阅读1.3k次,点赞29次,收藏18次。【教学类-18-05】20241118正方形手工纸(蒙德里安-风格派-红…

langchain--(4)

7 Embedding文本向量化 Embedding文本向量化是一种将非结构化文本转化为低维、连续数值向量的技术,旨在通过数学方式捕捉文本的语义、语法或特征信息,从而让机器更高效地处理语言任务。其核心思想源于流形假设(Manifold Hypothesis),即认为高维原始数据(如文本)实际隐含…

DMDRS部署实施手册(ORACLE=》DM)

DMDRS部署实施手册&#xff08;ORACLE》DM&#xff09; 1 同步说明2 DMDRS安装3 数据库准备3.1 源端准备3.1.1 开启归档日志和附加日志3.1.2 关闭回收站3.1.3 创建同步用户 3.2 目标准备3.2.1 创建同步用户 4 DMDRS配置4.1 源端配置4.2 目标配置 5 DMDRS启动5.1 启动源端服务5.…

十(1)作业:sqli-labs重点关卡

参考文章&#xff1a;详细sqli-labs&#xff08;1-65&#xff09;通关讲解-CSDN博客 第1关&#xff1a; 输入 &#xff1a; ?id3 输入 &#xff1a; ?id2 当输入的数字不同&#xff0c;页面的响应也不同&#xff0c;说明&#xff0c;输入的内容被带入到数据库里查询了 输…

Python 爬虫入门 Day 7 - 复盘 + 实战挑战日

Python 第二阶段 - 爬虫入门 &#x1f3af; 本周知识回顾 网络请求与网页结构基础 HTML解析入门&#xff08;使用 BeautifulSoup&#xff09; 实现爬虫多页抓取与翻页逻辑 模拟登录爬虫与 Session 维持 使用 XPath 进行网页解析&#xff08;lxml XPath&#xff09; 反爬虫应对…

WebRTC(七):媒体能力协商

目的 在 WebRTC 中&#xff0c;每个浏览器或终端支持的音视频编解码器、分辨率、码率、帧率等可能不同。媒体能力协商的目的就是&#xff1a; 确保双方能“听得懂”对方发的媒体流&#xff1b;明确谁发送、谁接收、怎么发送&#xff1b;保障连接的互操作性和兼容性。 P2P的基…

可信启动方案设计

安全之安全(security)博客目录导读 目录 一、引言 二、关键数据(Critical Data) 三、度量槽(Measurement Slot) 四、可信启动后端 1、事件日志(Event Log) 2、离散型 TPM(Discrete TPM) 3、RSE(运行时安全引擎) 五、平台接口 平台接口的职责: 1、函数:b…

✨通义万相2.1深度解析:AI视频生成引擎FLF2V-14B全流程指南(命令行参数+模型架构+数据流)

&#x1f31f; 从零详解&#xff1a;如何用AI模型生成视频&#xff1f;命令行、模型结构、数据流全解析&#xff01; 本文通过一个实际案例&#xff0c;详细解析使用AI模型生成视频的整个流程。从命令行参数解读到模型结构&#xff0c;再到数据在模型间的流动&#xff0c;一步步…

在 TypeScript 前端中使用 Umi-Request 调用 Java 接口的完整指南

下面我将详细介绍如何在基于 TypeScript 的前端项目中使用 umi-request 调用 IntelliJ IDEA 中开发的 Java 接口&#xff0c;包括完整的实现方案和代码示例。 整体方案设计 一、Java 后端接口准备 1. 创建 Spring Boot 控制器 // src/main/java/com/example/demo/controller…

GO Gin Web框架面试题及参考答案

目录 Gin 与 net/http 有哪些主要区别?为什么选择 Gin? 如何使用 Gin 启动一个 HTTP 服务并设置默认路由? Gin 的默认路由和自定义路由器组是如何工作的? 如何在 Gin 中绑定请求参数(Query、Form、JSON、XML)? 如何在 Gin 中使用中间件?中间件执行顺序是怎样的? …

asp.net core Razor动态语言编程代替asp.net .aspx更高级吗?

For Each item In products<tr><td>item.Id</td><td>item.Name</td><td>item.Price.ToString("C")</td></tr>Next为什么要用<tr> ? 在Blazor的Razor语法中&#xff0c;使用<tr>是为了在VB.NET代码块中…

css语法中的选择器与属性详解:嵌套声明、集体声明、全局声明、混合选择器

嵌套声明 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>嵌套声明</title> <!-- 这里p span 的含义是p标签下面的span标签 所以有嵌套关系--><style>p span {font-weight:…

Linux 系统中,/usr/bin/ 和/bin/的区别?

在 Linux 系统中&#xff0c;/bin/ 和 /usr/bin/ 都是存放可执行程序&#xff08;命令&#xff09;的目录&#xff0c;但它们在历史定位、用途、挂载策略和系统设计上有一定区别。 ✅ 快速对比总结 项目/bin//usr/bin/全称含义binary&#xff08;核心二进制&#xff09;user b…

苍穹外卖--WebSocket、来单提醒、客户催单

WebSocket 1.介绍 WebSocket是基于TCP的一种新的网络协议。它实现了浏览器与服务器全双工通信——浏览器和服务器只需要一次握手&#xff0c;两者之间就可以创建持久性的连接&#xff0c;并进行双向数据传送。 HTTP协议和WebSocket协议对比&#xff1a; ①Http是短连接 ②W…

Linux 信号(Signal)与信号量(Semaphore)区别

特性信号 (Signal)信号量 (Semaphore)本质软件中断进程间同步机制用途通知进程发生了某个事件控制对共享资源的访问通信方向单向 (内核→进程 或 进程→进程)多进程共享数据类型整数信号编号内核维护的计数器持久性瞬时,不排队持久,直到显式释放实现层次内核实现内核或用户空…

华为OD机考-观看文艺汇演问题-区间问题(JAVA 2025B卷)

import java.util.*; /*** version Ver 1.0* date 2025/6/20* description 观看文艺汇演*/ public class WatchMovie {public static void main(String[] args) {Scanner sc new Scanner(System.in);int num Integer.parseInt(sc.nextLine());List<Movie> movies new …

DeepSeek今天喝什么随机奶茶推荐器

用DeepSeek生成了一个随机奶茶推荐器-今天喝什么&#xff0c;效果非常棒&#xff01;UI界面美观。 提示词prompt如下 用html5帮我生成一个今天喝什么的网页 点击按钮随机生成奶茶品牌等&#xff0c;要包括中国常见的知名的奶茶品牌 如果不满意还可以随机再次生成 ui界面要好看 …

【国产AI服务器】全国产PCIE5.0交换板,替代博通89104/89144,支持海光、龙芯等平台

实物图 核心硬件配置 1、控制器芯片‌ 采用国产TL63104控制芯片‌&#xff0c;支持2.5GT/s、5GT/s、8GT/s、16GT/s、32GT/s的PCIe传输速率&#xff0c;支持968Lanes。支持6个x16的group和1个x8的group&#xff0c;每个group支持1至8个端口。x16group支持x16、x8、x4、x2端口…

GPIO-LED驱动

一、LED引脚说明 寄存器地址地图&#xff1a; 原理图&#xff1a; 关于MOS管的说明&#xff1a; 总结&#xff1a;当GPIO0_B5这个引脚输出高电平的时候&#xff0c;对应的N-MOS管导通—LED点亮 当GPIO0_B5这个引脚输出低电平的时候&#xff0c;对应的N-MOS管截止---LED熄灭 二…

Gartner《Generative AI Use - Case Comparison for Legal Departments》

概述 这篇文章由 Gartner, Inc. 出品,聚焦于生成式人工智能(GenAI)在法律部门中的应用情况,通过对 16 个较为突出的 GenAI 法律技术应用场景进行分析,从商业价值和可行性两个维度进行评估,旨在为法律总顾问等提供战略对话依据,以便更好地做出技术投资决策,推动法律部门…