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

【唐氏题目 nt题】与众不同

# 与众不同

## 题目描述

A是某公司的CEO,每个月都会有员工把公司的盈利数据送给A,A是个与众不同的怪人,A不注重盈利还是亏本,而是喜欢研究「完美序列」:一段连续的序列满足序列中的数互不相同。  
A想知道区间[L,R]之间最长的完美序列长度。

## 输入格式

第一行两个整数N,M,N表示连续N个月,编号为0到N−1,M表示询问的次数;  
第二行N个整数,第i个数表示该公司第i个月的盈利值ai;  
接下来M行每行两个整数L,R,表示A询问的区间。

## 输出格式

输出M行,每行一个整数对应询问区间内的完美序列的最长长度。

## 样例 #1

### 样例输入 #1

```
9 2
2 5 4 1 2 3 6 2 4
0 8
2 6
```

### 样例输出 #1

```
6
5
```

## 提示

1≤N,M≤2×10^5,0≤L≤R≤N−1,∣ai∣≤10^6。

为何唐氏

下标不按正常人习惯走,题目背景纯纯脑残,sb老板研究牛魔的完美序列。

浪费了一个小时,调题,强忍着怒火AC了。

核心思路

注意到 list 数组具有单调不减性

AC 代码

#include<bits/stdc++.h>
using namespace std;
const int N = 1e6+8; 
struct node{int mx,nx;
};
struct sgt{int a[1010000];int mx[4000010],nx[4000010];int n;void build(int p,int l,int r){if(l == r){mx[p] = nx[p] = a[l];return;}int mid = (l+r)/2;build(p*2,l,mid);build(p*2+1,mid+1,r);mx[p] = max(mx[p*2],mx[p*2+1]);nx[p] = min(nx[p*2],nx[p*2+1]);}node query(int p,int left,int right,int l,int r){if(l == left&&r == right){node ans;ans.mx = mx[p];ans.nx = nx[p];return ans;}int mid = (left+right)/2;if(r <= mid){return query(p*2,left,mid,l,r);}else if(l > mid){return query(p*2+1,mid+1,right,l,r);}else{node L = query(p*2,left,mid,l,mid);node R = query(p*2+1,mid+1,right,mid+1,r);node ans;ans.mx = max(L.mx,R.mx);ans.nx = min(L.nx,R.nx);return ans;}}
}t;
int n,m;
int last[N],f[N];
map<int,int>cnt;
int find(int L,int r){int le = L,ri = r;while(le < ri){int mid = (le+ri)/2;if(last[mid] >= L)ri = mid;else le = mid+1;}return le;
}
int main(){//ios::sync_with_stdio(0);int n,m;cin>>n>>m;for(int i = 1;i <= n;i++){int num;cin>>num;last[i] = max(last[i-1],cnt[num]+1);f[i] = i-last[i]+1;cnt[num] = i;t.a[i] = f[i];}t.build(1,1,n);for(int i = 1;i <= m;i++){int L,r;cin>>L>>r;L++,r++;int x = (find(L,r+1));if(x <= r){int ans1 = x-L;cout<<max(ans1,t.query(1,1,n,x,r).mx)<<endl;}else{cout<<r-L+1<<endl;}}
}

相关文章:

【唐氏题目 nt题】与众不同

# 与众不同 ## 题目描述 A是某公司的CEO&#xff0c;每个月都会有员工把公司的盈利数据送给A&#xff0c;A是个与众不同的怪人&#xff0c;A不注重盈利还是亏本&#xff0c;而是喜欢研究「完美序列」&#xff1a;一段连续的序列满足序列中的数互不相同。 A想知道区间[L,R]之…...

2000块的活嫌低?这个 6 位数的项目,你可不能错过哟!

2000块钱嫌低&#xff1f;这个6位数的项目&#xff0c;你可不能错过&#xff0c;关注有好礼。 最近写了一篇“接了一个2000块钱的活&#xff0c;大家看看值不值”的文章&#xff0c;发现流量和大家互动的热情出奇的高&#xff0c;可能是跟有钱有关的缘故&#xff0c;大家不是奔…...

【Postman工具】

一.接口扫盲 1.什么是接口&#xff1f; 接口是系统之间数据交互的通道。拿小红到沙县点餐为例&#xff1a;小红想吃鸭腿饭。她要用什么语言来表达&#xff1f;跟谁表达&#xff1f;通过什么表达&#xff1f;按照生活习惯应该是&#xff1a;小红根据菜单对服务员用中文表达她想要…...

全网超详细攻略-从入门到精通haproxy七层代理

目录 一.haproxy概述 1.1 haproxy简介 1.2 haproxy的主要特性 1.3 haproxy的优缺点 二.负载均衡介绍 2.1 什么是负载均衡 2.2 为什么用负载均衡 2.3 负载均衡类型 2.3.1 四层负载均衡 2.3.2 七层负载均衡 2.3.3 四层和七层的区别 三.haproxy的安装及服务 3.1 实验环…...

AI编程辅助工具:CodeGeeX 插件使用

CodeGeeX 插件使用 前言1.支持的平台2.安装步骤3.启用插件4.代码生成5.代码优化 前言 CodeGeeX 是一款基于 AI 技术的编程助手插件&#xff0c;旨在帮助开发者提高编程效率和代码质量。它能够智能生成代码、优化现有代码、自动生成文档以及回答编程相关的问题。无论您是初学者…...

sql注入实战——thinkPHP

sql注入实战——thinkPHP sql注入实战——thinkPHPthinkPHP前期环境搭建创建数据库开始寻找漏洞点输入SQL注入语句漏洞分析 实验错误 sql注入实战——thinkPHP thinkPHP前期环境搭建 下载thinkPHP文件 解压&#xff0c;将framework关键文件放到think-5.0.15中&#xff0c;改…...

MySQL 迁移 OceanBase 的 Oracle模式中,实现自增主键的方法

本文作者&#xff1a;赵黎明&#xff0c;爱可生 MySQL DBA 团队成员&#xff0c;熟练掌握Oracle、MySQL等数据库系统&#xff0c;擅长对数据库性能问题的诊断&#xff0c;以及事务与锁机制的分析等。负责解决客户在MySQL及爱可生自主研发的DMP平台日常运维中所遇到的各种问题&a…...

【C++ 面试 - 基础题】每日 3 题(十一)

✍个人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/fYaBd &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞&#x1f44d;收藏&…...

ESP8266在线升级OTA固件

OTA的基本实现方式&#xff1a; ESP8266 的 OTA 实现有几种方式&#xff0c;常用的方式包括&#xff1a; 1、Arduino OTA&#xff1a;使用Arduino IDE提供的OTA功能&#xff0c;可以直接通过Arduino IDE上传固件到ESP8266。 2、Web OTA&#xff1a;ESP8266运行一个简易的Web服…...

精通C++ STL(六):list的模拟实现

目录 类及其成员函数接口总览 结点类的模拟实现 构造函数 迭代器类的模拟实现 迭代器类存在的意义 迭代器类的模板参数说明 构造函数 运算符的重载 --运算符的重载 运算符的重载 !运算符的重载 *运算符的重载 ->运算符的重载 list的模拟实现 默认成员函数 构造函数 拷贝…...

《雅思口语真经总纲1.0》话题实战训练笔记part1——6. Music

《雅思口语真经总纲1.0》笔记——第四章&#xff1a;口语素材大全&#xff08;part1、part2、part3回答准则及练习方法&#xff0c;不包括范例答案&#xff09;★★★★★ 文章目录 MusicWhen do you listen to music?20240804答评价注意事项1、在说到“no music”时&#xff…...

Python之赋值语句(多重赋值和交换赋值)

这是《Python入门经典以解决计算问题为导向的Python编程实践》73-74页关于赋值的内容。讲了Python中几种赋值方式。 赋值语句 1、最简单的赋值&#xff1a;ab2、多重赋值&#xff1a;a,b,c1,2,33、交换&#xff1a;a,bb,a 1、最简单的赋值&#xff1a;ab b可以是数字、字符串…...

网络协议七 应用层 HTTP 协议

应用层常见的协议 HTTP协议 1. 如何查看我们的http 协议全部的内容有哪些呢&#xff1f; 一种合理的方法是 通过 wireshark 软件&#xff0c;找到想要查看的HTTP --->追踪流--->HTTP流 来查看 结果如下&#xff1a;红色部分 为 发送给服务器的&#xff0c;蓝色部分为服务…...

uniapp vue 在适配百度小程序平台动态:style

uniapp vue 在适配百度小程序平台动态:style踩坑报错Unexpected string concatenation of literals 抖快平台动态style写法基本是 <view :style"{width: 686rpx, height: (setHeight 96) rpx}"> </view>这种写法在百度上会又解析报错&#xff1a; Une…...

【最小生成树】(二) Kruskal 算法

题目: 寻宝 题目描述 在世界的某个区域&#xff0c;有一些分散的神秘岛屿&#xff0c;每个岛屿上都有一种珍稀的资源或者宝藏。国王打算在这些岛屿上建公路&#xff0c;方便运输。 不同岛屿之间&#xff0c;路途距离不同&#xff0c;国王希望你可以规划建公路的方案&#xf…...

haproxy最强攻略

1、负载均衡 负载均衡&#xff08;Load Balance&#xff0c;简称 LB&#xff09;是高并发、高可用系统必不可少的关键组件&#xff0c;目标是 尽力将网络流量平均分发到多个服务器上&#xff0c;以提高系统整体的响应速度和可用性。 负载均衡的主要作用如下&#xff1a; 高并发…...

XetHub 加入 Hugging Face!

我们非常激动地正式宣布&#xff0c;Hugging Face 已收购 XetHub &#x1f525; XetHub 是一家位于西雅图的公司&#xff0c;由 Yucheng Low、Ajit Banerjee 和 Rajat Arya 创立&#xff0c;他们之前在 Apple 工作&#xff0c;构建和扩展了 Apple 的内部机器学习基础设施。XetH…...

在编程学习的海洋中,如何打造高效的知识宝库

目录 在编程学习的海洋中&#xff0c;如何打造高效的知识宝库一、笔记记录的重要性&#xff1a;为知识设立灯塔二、快速记录的策略&#xff1a;抓住知识的核心三、系统化的整理&#xff1a;构建个人知识体系四、实用工具推荐&#xff1a;为知识管理添砖加瓦五、保持条理性的秘诀…...

string详解(1)

1.C语言中的字符串 C语言中&#xff0c;字符串是以\0结尾的一些字符的集合&#xff0c;为了操作方便&#xff0c;C标准库中提供了一些str系列的库函数&#xff0c;但是这些库函数与字符串是分离开的&#xff0c;不太符合OOP的思想&#xff0c;而且底层空间需要用户自己管理&…...

Linux云计算 |【第二阶段】NETWORK-DAY4

主要内容&#xff1a; NAT 原理与配置&#xff08;私有IP地址、静态NAT转换、Easy IP&#xff09;、VRRP解析&#xff08;主路由器、备份路由器、虚拟路由器、优先级&#xff09; 一、NAT概述 NAT 网络地址转换&#xff08;Network Address Translation&#xff09;是一种网络…...

三维空间智能体(3D Spatial Agent)的目标连续感知与主动控制技术体系研究与应用:专家评审18问18答

一、学术与原理类&#xff08;1–6&#xff09;Q1&#xff1a;你们所谓“像素即坐标”&#xff0c;在理论上如何成立&#xff1f;误差如何界定&#xff1f;A&#xff1a; 基于多视角几何与相机内外参标定&#xff0c;将像素反投影为空间射线&#xff0c;通过多视角交汇&#xf…...

告别论文 “红标警告”!Paperxie 四大降重降 AIGC 功能:让本科生毕业通关率飙升

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/AIPPThttps://www.paperxie.cn/weight?type1https://www.paperxie.cn/weight?type1 一、 论文人的崩溃瞬间&#xff1a;查重红了&#xff0c;AIGC 标了&#xff0c;答辩悬了 你有没有过这样的经历&#…...

从 99.8% 到 14.9%!Paperxie 降重 / 降 AIGC:本科生毕业论文的 “救命神器” 全拆解

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/AIPPThttps://www.paperxie.cn/weight?type1https://www.paperxie.cn/weight?type1 一、写在前面&#xff1a;被论文查重和 AIGC 检测逼到崩溃的你&#xff0c;真的不是一个人 凌晨三点的宿舍&#xff0…...

揭秘openGauss向量化执行引擎代价模型

揭秘openGauss向量化执行引擎代价模型openGauss的向量化执行引擎针对列存&#xff0c;生成执行计划后根据配置项是否开启直接决定是否将执行计划转换成向量化执行计划来执行。若向量化执行引擎在行存上执行就需要将数据转换成VectorBatch即列存的形式才可执行&#xff0c;这个转…...

Vue.js核心原理之VNode如何映射真实DOM元素流程全解

VNode是Vue中描述DOM结构的轻量、可比较、不可变的JavaScript对象&#xff0c;包含tag、data、children等字段&#xff0c;不直接操作DOM&#xff0c;其真实DOM绑定和更新由patch过程完成。Vue.js 中的 VNode&#xff08;虚拟节点&#xff09;是实现响应式更新和高效 DOM 操作的…...

健身私教AI:OpenClaw+Qwen3.5-9B定制个人训练计划与饮食建议

健身私教AI&#xff1a;OpenClawQwen3.5-9B定制个人训练计划与饮食建议 1. 为什么需要AI健身私教&#xff1f; 去年冬天体检报告上的"轻度脂肪肝"三个字&#xff0c;成了我决定认真健身的最后一根稻草。作为程序员&#xff0c;我试过各种健身APP&#xff0c;但总感…...

Agent间数据流与控制流分离:构建可复用的协作架构

Agent间数据流与控制流分离:构建可复用的协作架构 一、 摘要/引言 1.1 开门见山:从一场“失控的Multi-Agent协作”讲起 上周六,我帮同事复盘他们团队的电商智能客服Agent集群上线事故——那天下午6点到8点,正好是618预热的第三波“整点蹲优惠券码”活动,负责规则推理优惠…...

告别环境冲突|Anaconda实战:AI开发全流程(数据→训练→部署)环境标准化指南,建议收藏

摘要&#xff1a;告别环境冲突、依赖地狱、复现失败&#xff01;本文以 Anaconda 为核心&#xff0c;打造一套可复制、可迁移、可团队协作的 AI 全流程标准化方案&#xff0c;覆盖环境初始化→数据预处理→模型训练→打包部署&#xff0c;一套流程通吃个人实验与工程落地。前言…...

【实战解读】腾讯云ClawPro正式发布:企业版OpenClaw 10分钟上线,三级Token配额+四层安全防护全解析

腾讯云正式发布企业版OpenClaw——ClawPro&#xff0c;定位为一站式企业AI智能体管控平台。本文从产品定位、三级Token配额体系、四层安全防护、技术架构、部署实操等角度做深度解读&#xff0c;帮助企业技术决策者评估是否适合引入ClawPro。附部署流程和成本分析。 目录前言一…...

STM32开发库对比:寄存器、SPL、HAL与LL深度解析

1. STM32开发库全景解析&#xff1a;从寄存器到HAL/LL的深度对比从事嵌入式开发这些年&#xff0c;我见证了STM32生态系统的快速演进。记得刚接触STM32F103时&#xff0c;标准外设库还是主流选择&#xff0c;如今Cube生态已成标配。本文将结合我的实际项目经验&#xff0c;详细…...