P1886 滑动窗口P1886 滑动窗口
problemproblem
RMQRMQ问题
还是用线段树 =-=
(线段树好难调试啊QwQQwQ)
这题与P1440 求m区间内的最小值 非常相似
就不仔细讲了
改两个地方就AC一题
#include <bits/stdc++.h>
using namespace std ;
inline int rd() { int x = 0 ; int f = 1 ; register char c ;
#define gc c = getchar()
while(isspace(gc)) ;
if(c == '-') f = -1 , gc ;
while(x = (x<<1) + (x<<3) + (c&15) , isdigit(gc)) ;
return x * f ;
#undef gc
}
const int inf = INT_MAX >> 1 ;
const int N = 1e6 + 10 ;
struct node {
int l , r ;
int Min , Max ;
#define lt k << 1
#define rt k << 1 | 1
}tree[N << 2] ;
int n , m ;
int a[N] ;
inline void build(int k,int l,int r) {
if(l > r) return ;
if(l == r) {
tree[k].l = l , tree[k].r = r ;
tree[k].Min = a[l] ;
tree[k].Max = a[l] ;
return ;
}
int mid = (l + r) >> 1 ;
build(lt , l , mid) ;
build(rt , mid + 1 , r) ;
tree[k].l = l , tree[k].r = r ;
tree[k].Min = min(tree[lt].Min , tree[rt].Min) ;
tree[k].Max = max(tree[lt].Max , tree[rt].Max) ;
}
inline int query(int k,int l,int r,int x,int y) {
if(l > r) return 0 ;
if(l >= x and r <= y) return tree[k].Min ;
int mid = (l + r) >> 1 ;
int sum = inf ;
if(x <= mid) sum = min(sum , query(lt , l , mid , x , y)) ;
if(y > mid) sum = min(sum , query(rt , mid + 1 , r , x , y)) ;
return sum ;
}
inline int Query(int k,int l,int r,int x,int y) {
if(l > r) return 0 ;
if(l >= x and r <= y) return tree[k].Max ;
int mid = (l + r) >> 1 ;
int sum = -inf ;
if(x <= mid) sum = max(sum , Query(lt , l , mid , x , y)) ;
if(y > mid) sum = max(sum , Query(rt , mid + 1 , r , x , y)) ;
return sum ;
}
signed main() {
for(register int i=1;i<=(N<<2);i++) tree[i].Max = -inf , tree[i].Min = inf ;
n = rd() , m = rd() ;
for(register int i=1;i<=n;i++) a[i] = rd() ;
build(1 , 1 , n) ;
for(register int i=m;i<=n;i++) {
int x = i - m + 1 , y = i ;
printf("%d " , query(1 , 1 , n , x , y)) ;
}
puts("") ;
for(register int i=m;i<=n;i++) {
int x = i - m + 1 , y = i ;
printf("%d " , Query(1 , 1 , n , x , y)) ;
}
return 0 ;
}
不存在十全十美的文章 如同不存在彻头彻尾的绝望
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
· .NET 适配 HarmonyOS 进展
· 本地部署 DeepSeek:小白也能轻松搞定!
· 如何给本地部署的DeepSeek投喂数据,让他更懂你
· 从 Windows Forms 到微服务的经验教训
· 李飞飞的50美金比肩DeepSeek把CEO忽悠瘸了,倒霉的却是程序员
· 超详细,DeepSeek 接入PyCharm实现AI编程!(支持本地部署DeepSeek及官方Dee