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

题解:洛谷 P1955 [NOI2015] 程序自动分析

【题目来源】

洛谷:[P1955 NOI2015] 程序自动分析 - 洛谷

【题目描述】

在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足。

考虑一个约束满足问题的简化版本:假设 \(x_1,x_2,x_3,\dots\) 代表程序中出现的变量,给定 \(n\) 个形如 \(x_i=x_j\)\(x_i\neq x_j\) 的变量相等/不等的约束条件,请判定是否可以分别为每一个变量赋予恰当的值,使得上述所有约束条件同时被满足。例如,一个问题中的约束条件为:\(x_1=x_2,x_2=x_3,x_3=x_4,x_4\neq x_1\),这些约束条件显然是不可能同时被满足的,因此这个问题应判定为不可被满足。

现在给出一些约束满足问题,请分别对它们进行判定。

【输入】

输入的第一行包含一个正整数 \(t\),表示需要判定的问题个数。注意这些问题之间是相互独立的。

对于每个问题,包含若干行:

第一行包含一个正整数 \(n\),表示该问题中需要被满足的约束条件个数。接下来 \(n\) 行,每行包括三个整数 \(i,j,e\),描述一个相等/不等的约束条件,相邻整数之间用单个空格隔开。若 \(e=1\),则该约束条件为 \(x_i=x_j\)。若\(e=0\),则该约束条件为 \(x_i\neq x_j\)

【输出】

输出包括 \(t\) 行。

输出文件的第 \(k\) 行输出一个字符串 YES 或者 NO(字母全部大写),YES 表示输入中的第 \(k\) 个问题判定为可以被满足,NO 表示不可被满足。

【输入样例】

2
2
1 2 1
1 2 0
2
1 2 1
2 1 1

【输出样例】

NO
YES

【解题思路】

image

【算法标签】

《洛谷 P1955 程序自动分析》 #并查集# #离散化# #哈希,hash# #NOI# #2015#

【代码详解】

#include <bits/stdc++.h>
using namespace std;const int N = 100005;  // 定义最大数据量int t, n, cnt;         // t: 测试用例数, n: 每个用例的关系数, cnt: 离散化计数器
int a[N], b[N], e[N];   // a,b: 关系中的两个元素, e: 关系类型(1-同集合,0-不同集合)
int p[N*2];             // 并查集父节点数组(开两倍空间)
unordered_map<int, int> mp;  // 离散化映射表/*** 查找根节点(带路径压缩)* @param x 当前节点* @return 根节点*/
int find(int x)
{return p[x] == x ? x : p[x] = find(p[x]);
}/*** 离散化函数* @param x 原始值* @return 离散化后的值*/
int get(int x)
{if (mp.count(x) == 0) mp[x] = ++cnt;  // 如果未映射过,分配新编号return mp[x];
}int main()
{cin >> t;  // 输入测试用例数while (t--) {cnt = 0;        // 重置离散化计数器mp.clear();     // 清空映射表cin >> n;       // 输入关系数// 初始化并查集(开两倍空间)for (int i = 1; i <= n * 2; i++) {p[i] = i;}// 输入并离散化所有关系for (int i = 1; i <= n; i++) {cin >> a[i] >> b[i] >> e[i];a[i] = get(a[i]);b[i] = get(b[i]);}// 处理同集合关系(合并集合)for (int i = 1; i <= n; i++) {if (e[i] == 1) {int x = find(a[i]), y = find(b[i]);if (x != y) p[x] = y;  // 合并集合}}// 检查不同集合关系是否矛盾bool flag = true;for (int i = 1; i <= n; i++) {if (e[i] == 0 && find(a[i]) == find(b[i])) {flag = false;  // 发现矛盾break;}}// 输出结果flag ? puts("YES") : puts("NO");}return 0;
}

【运行结果】

2
2
1 2 1
1 2 0
NO
2
1 2 1
2 1 1
YES
http://www.jsqmd.com/news/391976/

相关文章:

  • 题解:洛谷 P1892 [BalticOI 2003] 团伙
  • 计算机视觉opencv之金字塔直方图 - 详解
  • 题解:洛谷 P1229 遍历问题
  • 百联OK卡回收攻略:快速实现交易,解决常见问题 - 团团收购物卡回收
  • 西门子 博图V15洁净室温湿度串级控制结构化编程 使用串级PID的方式控制空调的回风,送风的温...
  • 英语_作文练习_Curiosity Leads Me_待读
  • 题解:洛谷 P5266 【深基17.例6】学籍管理
  • 题解:洛谷 P1918 保龄球
  • 2026评价好的接线防爆箱供应商怎么选?秘籍大揭秘,住宅配电柜/高压配电柜/金属封闭高压柜,防爆箱厂家怎么选择 - 品牌推荐师
  • 2026金相镶嵌机供应商推荐,性能稳定更可靠,单点加力金相磨抛机/试验机/电动洛氏硬度计,金相镶嵌机企业找哪家 - 品牌推荐师
  • 永辉超市卡怎么回收?实用技巧让你不再浪费! - 团团收购物卡回收
  • COMSOL仿真研究:单个金纳米颗粒光热效应的复现与波动光学、固体传热机理的探索
  • YOLOv12 改进 | Backbone改进 2
  • 生产环境【大模型学习】提示词工程(Prompt Engineering)技术深度报告最佳实践与性能优化
  • 学习笔记:连续子数组和问题的优化思路与工程实现思考
  • 学习笔记:二进制数组中0和1数量相等的最长连续子数组——从常规解法到性能优化
  • 量子网络:从理论到工程化探索
  • 分期乐购物额度回收平台推荐:省钱、省力的优选方法 - 团团收购物卡回收
  • PNG 转 JPG 在线工具推荐:免费、批量、无需注册的实用网站整理
  • 深入解析:基于机器学习的农产品价格数据分析与预测系统
  • 定稿前必看!10个降AIGC工具:继续教育降AI率全测评
  • 超级老龄化科技社会
  • 把vlm专门识别屏幕加入历史对话记录上下文中,​然后llm每两分钟参考历史记录对话这样效果好吗
  • 少走弯路:千笔AI,研究生降重首选利器
  • 脚本之轻 vs 程序之重:深度解析3DSMax两大插件生态的优劣与抉择 - 实践
  • 加油卡回收流程揭秘:平台选择与避坑技巧全解析 - 团团收购物卡回收
  • 详细介绍:P14978 [USACO26JAN1] Mooclear Reactor S题解
  • 硕士论文5万字AI率太高怎么办?大论文降AI全攻略
  • 文科生论文AI率特别高?原因和解决方案都在这了
  • 2070年人口数量可能降低一半,剩下7亿人。采用AI + 机器人来应对的可能和可行性有多大?