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

2024-03-14 08:36

本文主要是介绍P1955 [NOI2015] 程序自动分析题解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

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

考虑一个约束满足问题的简化版本:假设x1​,x2​,x3​,⋯ 代表程序中出现的变量,给定n个形如xi​=xj​或xi​!=xj​ 的变量相等/不等的约束条件,请判定是否可以分别为每一个变量赋予恰当的值,使得上述所有约束条件同时被满足。例如,一个问题中的约束条件为:x1​=x2​,x2​=x3​,x3​=x4​,x4​!=x1​,这些约束条件显然是不可能同时被满足的,因此这个问题应判定为不可被满足。

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

输入输出格式

输入格式

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

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

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

输出格式

输出包括t行。

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

输入输出样例

输入样例

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

输出样例

NO
YES

解析

这个题目采用并查集解决,先根据e值的大小将式子进行排序,先处理相等的式子,将相等的式子合并在一个集合里面,然后处理不等的式子,如果不等的式子出现在同一个集合里面,那么直接返回NO,如果没有返回YES。这个题目由于数据比较大,所以将数据离散化将空间进行压缩。

#include<cstdio>
#include<map>
#include<algorithm>
using namespace std;
const int max_n=200005;
struct node{int l,r,e;
}m[100005];
int f[max_n];
bool cmp(node a,node b){return a.e>b.e;
}
int find(int x){if(f[x]!=x){f[x]=find(f[x]);}return f[x];
}
void ad(int x,int y){x=find(x);y=find(y);if(x==y){return;}f[x]=y;
}
void judge(){int n,mark=1;//使用mark进行离散化数据压缩空间scanf("%d",&n);map<int,int> ds;for(int i=1;i<=n;i++){scanf("%d%d%d",&m[i].l,&m[i].r,&m[i].e);if(!ds[m[i].l]){ds[m[i].l]=mark;mark++;}if(!ds[m[i].r]){ds[m[i].r]=mark;mark++;}}sort(m+1,m+1+n,cmp);for(int i=1;i<=n;i++){if(m[i].e){ad(ds[m[i].l],ds[m[i].r]);}else{if(find(ds[m[i].l])==find(ds[m[i].r])){printf("NO\n");return;}}}printf("YES\n");
}
int main(){int t;scanf("%d",&t);while(t--){for(int i=1;i<=max_n;i++){f[i]=i;}judge();}return 0;
}

这篇关于P1955 [NOI2015] 程序自动分析题解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/807822

相关文章

SpringBoot实现RSA+AES自动接口解密的实战指南

《SpringBoot实现RSA+AES自动接口解密的实战指南》在当今数据泄露频发的网络环境中,接口安全已成为开发者不可忽视的核心议题,RSA+AES混合加密方案因其安全性高、性能优越而被广泛采用,本... 目录一、项目依赖与环境准备1.1 Maven依赖配置1.2 密钥生成与配置二、加密工具类实现2.1

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略