社区讨论
90分求调
P1816忠诚参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @mjh1p3of
- 此快照首次捕获于
- 2025/12/22 19:00 3 个月前
- 此快照最后确认于
- 2025/12/25 10:10 2 个月前
神秘的单调队列做法
CPP#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 5;
int m, n;
int a[N], x, y;
deque<int> nums;
void solve(int x, int y) {
for (int i = 1; i <= n; i ++) {
while (!nums.empty() && a[nums.back()] >= a[i]) nums.pop_back();
nums.push_back(i);
}
printf("%d ", a[nums.front()]);
}
int main() {
scanf("%d %d", &m, &n);
for (int i = 1; i <= m; i ++) scanf("%d", &a[i]);
for (int i = 1; i <= n; i ++) {
scanf("%d %d", &x, &y);
solve(x, y);
while (!nums.empty()) nums.pop_back();
}
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...