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

MC0461排队

码蹄集OJ-排队

问题描述

唐僧师徒四人历经千辛万苦取得真经后,天庭决定为所有参与取经的众生灵举办一场庆功宴。然而,宴会入口处有 n 个生灵排队,每个生灵都提出了自己的 “站位要求”:

  1. 金蟾精型opt = 1):“我前面至少有 x 个生灵,否则我站不稳!” 即该生灵的位置 pos 需满足 pos >= x + 1(排队位置从 1 开始计数 )。
  2. 紧箍咒型opt = 2):“我前面至多有 x 个生灵,否则我念咒头疼!” 即该生灵的位置 pos 需满足 pos <= x + 1 。
  3. 如来神掌型opt = 3):“我前面至少有 x 个生灵,至多有 y 个生灵,否则我施展不开!” 即该生灵的位置 pos 需满足 x + 1 <= pos <= y + 1 。

若存在一种排队方式,使得所有生灵的要求都得到满足,请输出 Y,否则输出 N 。

输入格式

  • 第一行一个整数 T1 ≤ T ≤ 10^6),表示测试数据组数。
  • 对于每组测试数据:
    • 第一行一个整数 n1 ≤ n ≤ 10^6)。
    • 接下来 n 行,每行第一个输入一个整数 optopt ∈ {1,2,3}),如果 opt = 1 或者 opt = 2,接着输入一个整数 x;否则如果 opt = 3,接着输入两个整数 x, y,数据满足:0 ≤ x, y < n ;分别表示每个生灵提出的要求。
  • 数据保证:∑n ≤ 10^6 。

输出格式

对于每组测试数据:输出一行一个字符 Y 或者 N,表示答案。

样例 1

输入

2
3
2 0
1 2
3 0 1
2
3 0 0
3 0 0

输出

Y
N

代码:

#include<bits/stdc++.h>
using namespace std;int n; 
struct node {int l, r; 
} a[1000010]; // 用于 sort 的比较函数,按区间左端点升序排序
bool cmp(node a, node b) 
{return a.l < b.l; 
}void solve() 
{cin >> n;int f = 1; for (int i = 1; i <= n; i++) { int op;cin >> op;if (op == 1) { int x;cin >> x;a[i].l = x + 1; a[i].r = n;     } else if (op == 2) { int x;cin >> x;a[i].l = 1;     a[i].r = x + 1; } else { int x, y;cin >> x >> y;a[i].l = x + 1; a[i].r = y + 1; if (x > y) {    f = 0;     }}}if (!f) { cout << "N\n";return;}// 按区间左端点排序sort(a + 1, a + n + 1, cmp); // 大顶堆,存储区间右端点,用于贪心选最小可行右端点priority_queue<int, vector<int>, greater<int>> q; for (int i = 1, j = 1; i <= n; i++) { // 将左端点 <= 当前位置 i 的区间,加入队列while (j <= n && a[j].l <= i) { q.push(a[j].r);j++;}if (!q.empty()) { if (q.top() >= i) { q.pop();}else { cout << "N\n";return;}} else { cout << "N\n";return;}}// 所有位置都成功分配cout << "Y\n"; 
}int main() 
{// 加速输入输出cin.tie(0), cout.tie(0); int t;cin >> t; while (t--) { solve();}return 0; 
}

http://www.dtcms.com/a/296876.html

相关文章:

  • 【时时三省】(C语言基础)怎样定义和使用指向函数的指针变量
  • 深入解析Java微服务架构请求流程:Nginx到Nacos的完整旅程
  • 数据库期中复习
  • JSONObject相关知识点
  • 嵌入式通信知识串讲:从同步 / 异步传输到 UART 协议 STM32F103 硬件解析
  • 大模型提示词漏洞攻防测试:技术分析与实践指南
  • 客户关系管理(CRM)百科:定义、价值及发展趋势
  • JMeter 性能测试实战笔记
  • Javascript NaN Symbol BigInt
  • 论文阅读:《无约束多目标优化的遗传算法,群体和进化计算》
  • 【25-cv-3322、25-cv-3323】Aeropostale连发两案!12个商标冻住600多家店铺
  • Android集成Google Map
  • 基于自适应控制算法的SVC与STATCOM联合优化
  • 如何在IEEE上检索文献|综述性文献
  • springboot 一键下载文件
  • Linux操作系统原理与应用
  • 河南萌新联赛2025第(二)场:河南农业大学
  • 使用Docker+Nginx部署电商平台项目(服务端+管理端+商城)
  • 基于STM32智能鱼缸监控投喂系统
  • Kubernetes 集群架构和Pod创建流程
  • 优选算法:移动零
  • 激光雷达的单播和广播模式介绍
  • 2025年海外短剧独立站开发:H5+PC端双平台技术实践与增长策略
  • 处理HTTP请求体:精通`@RequestBody`、`@RequestHeader`与`@CookieValue`
  • 计算机视觉技术剖析:轮廓检测、模板匹配及特征点匹配
  • SpringBoot框架简介
  • Windows本地部署DeepSeek
  • git更新内核补丁完整指南
  • 【C++】使用中值滤波算法过滤数据样本中的尖刺噪声
  • Java 并发容器:ConcurrentHashMap 笔记(JDK 1.8)