/*
2-sat
题意:给定一个圆,圆上一些点。两点一线。现给出一些线,这些线可以在圆内连起来,也可以在圆外。
问有没有可能所有的线画完 且 不出现相交。
思路:把线画在圆内或圆外 看成一个组合。其它的则建边。
*/
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<math.h>
#include<algorithm>
#include<iostream>
#include<set>
#include<stack>
#include<queue>
#include<map>
#include<vector>
using namespace std;
typedef long long int64;
//typedef __int64 int64;
typedef pair<int64,int64> PII;
#define MP(a,b) make_pair((a),(b))
const int maxn = 2225;
const int maxm = 250000;
const int inf = 0x7fffffff;
const double pi=acos(-1.0);
const double eps = 1e-8;
struct Edge{
int u,v,next;
}edge[ maxm*2+5 ];
int cnt,head[ maxn ];
int vis[ maxn ];
int dfn[ maxn ],low[ maxn ];
int belong[ maxn ],Cnt,id;
stack<int>s;
struct EDGE{
int l,r;
}E[ maxn ];
void init(){
id = Cnt = 0;
cnt = 0;
while( !s.empty() )
s.pop();
memset( head,-1,sizeof( head ) );
memset( vis,-1,sizeof( vis ) );
memset( dfn,-1,sizeof( dfn ) );
memset( low,-1,sizeof( low ) );
}
void addedge( int a,int b ){
edge[ cnt ].u = a;
edge[ cnt ].v = b;
edge[ cnt ].next = head[ a ];
head[ a ] = cnt++;
}
bool ok( int L,int R ){
int x1 = E[L].l;
int y1 = E[L].r;
int x2 = E[R].l;
int y2 = E[R].r;
if( x2>x1&&x2<y1 ){
if( y2>=y1 ) return true;
if( y2<=x1 ) return true;
}
if( y2>x1&&y2<y1 ){
if( x2>=y1 ) return true;
if( x2<=x1 ) return true;
}
return false;
}
void tarjan( int cur ){
dfn[ cur ] = low[ cur ] = id++;
vis[ cur ] = 1;
s.push( cur );
for( int i=head[ cur ];i!=-1;i=edge[i].next ){
int nxt = edge[ i ].v;
if( dfn[ nxt ]==-1 ){
tarjan( nxt );
low[ cur ] = min( low[ cur ],low[ nxt ] );
}
else if( vis[ nxt ]==1 ){
low[ cur ] = min( low[ cur ],dfn[ nxt ] );
}
}
if( dfn[ cur ]==low[ cur ] ){
Cnt ++;
while( 1 ){
int tmp = s.top();
s.pop();
vis[ tmp ] = 0;
belong[ tmp ] = Cnt;
if( tmp==cur ) break;
}
}
}
int main(){
int n,m;
while( scanf("%d%d",&n,&m)==2 ){
init();
int a,b;
for( int i=1;i<=m;i++ ){
scanf("%d%d",&a,&b);
a++,b++;
E[ i ].l = min( a,b );
E[ i ].r = max( a,b );
}
for( int i=1;i<=m;i++ ){
for( int j=i+1;j<=m;j++ ){
if( ok( i,j )==true ){
addedge( i,j+m );
addedge( j+m,i );
addedge( i+m,j );
addedge( j,i+m );
}
}
}//build mat
for( int i=1;i<=2*m;i++ ){
if( dfn[i]==-1 ){
tarjan( i );
}
}
//
bool f = true;
for( int i=1;i<=m;i++ ){
if( belong[i]==belong[i+m] ){
f = false;
break;
}
}
if( f==false ) printf("the evil panda is lying again");
else printf("panda is telling the truth...");
printf("\n");
}
return 0;
}
分享到:
相关推荐
在本篇文章中,我们将深入探讨POJ平台上的一系列经典图论问题,并根据提供的部分内容,总结出每个题目背后所涉及的核心算法和技术点。这些题目不仅考验了参赛者的逻辑思维能力,同时也对数据结构和算法的掌握提出了...
2.10.1 一类开关问题,对 2 取模的 01 方程组 . . . . . . . . . . . . . . . . . . . 37 2.10.2 解同余方程组 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 2.11 整数拆分 . . . . . . ....
cmd-bat-批处理-脚本-IE主页修改.zip
Delphi 12.3控件之uniGUI-Extras_1.95.0.1600.rar
内容概要:本文主要介绍了SQL注入的概念、危害及其防范措施。SQL注入是攻击者通过恶意构造输入,使服务器执行非预期的SQL命令的一种攻击方式,常因用户输入未
使用方法:拷贝到Auto CAD的Fonts下
cmd-bat-批处理-脚本-维护版.zip
解压
内容概要:本文档为《mysql.docx》,主要汇总了MySQL的各类常用命令,分为基础命令、数据库相关命令、数据表相关命令和事务相关命令四大部分。基础命令涵盖了连接、创建、删除数据库,创建和删除表,插入、查询、更新、删除数据等基本操作;数据库相关命令则进一步细化了对数据库的管理操作,如修改编码格式、查看数据库详细信息等;数据表相关命令着重介绍了对表结构和数据的操作,包括创建、修改、删除表,添加、删除、修改列,创建和删除索引等;事务相关命令主要涉及事务的开始、提交、回滚,设置事务隔离级别,以及表的锁定与解锁操作。; 适合人群:适用于具有一定SQL基础,尤其是MySQL使用经验的数据库管理员或开发人员。; 使用场景及目标:①帮助用户快速查找并正确使用MySQL的各种命令;②提高用户对MySQL数据库的操作能力,包括但不限于数据库和表的创建、修改、删除,数据的增删改查等;③掌握MySQL事务处理机制,确保数据的一致性和完整性。; 其他说明:本文档是MySQL命令的集合,建议用户在实际操作前先熟悉各个命令的具体用法,并在测试环境中进行练习,避免误操作导致数据丢失或其他严重后果。
cmd-bat-批处理-脚本-交换两个变量的值而不使用临时变量.zip
内容概要:集成测试是确保软件质量的关键环节,它在单元测试基础上验证模块间的交互和协作。文章详细介绍了集成测试的目的、重要性、流程步骤、策略与方法以及常见问题的解决办法。集成测试不仅验证模块接口的正确性,还确保系统的整体功能和性能符合预期。文章通过一个电商系统的实际案例,展示了集成测试在发现和解决问题中的具体应用。最后,展望了集成测试未来的发展趋势,如自动化测试、云计算、大数据和人工智能技术的应用。 适合人群:软件开发人员、测试工程师、项目经理及相关技术人员。 使用场景及目标:①了解集成测试在整个软件开发生命周期中的作用和重要性;②掌握集成测试的详细流程,包括测试计划制定、环境搭建、用例设计、执行与记录、缺陷管理和回归测试、测试总结与报告;③学习集成测试的不同策略(自顶向下、自底向上、混合策略)和方法(黑盒测试、白盒测试、模拟测试),并理解其适用场景;④掌握常见问题(接口不匹配、数据传递错误、性能瓶颈)的解决办法。 其他说明:本文不仅提供了集成测试的理论知识,还结合实际案例进行详细讲解,帮助读者更好地理解和应用集成测试技术。未来集成测试将受益于自动化测试、云计算、大数据和人工智能技术的发展,测试人员应不断学习新技术,优化测试流程,提高软件质量和效率。
cmd脚本-bat批处理-快速设定分辨率.zip
内容概要:本文献为电子科技大学硕士学位论文,题目为“高阶过采样delta-sigma DAC设计”。论文首先介绍了DAC的基本概念及其多种结构,重点阐述了delta-sigma DAC的优势,包括实现24位以上量化精度、简化模拟部分设计等。接着详细探讨了delta-sigma DAC的核心组成部分——过采样和噪声整形。过采样部分采用8倍插值8倍采样保持结构,其中插值器由2倍和4倍插值器级联构成;噪声整形部分采用5阶结构,优化了零点和极点,形成前馈加局部振荡反馈的噪声整形环。论文还介绍了在Matlab中完成的数字模型和FPGA平台上实现的硬件设计,最终实现了16位数据位宽、信噪比为95.53dB的delta-sigma DAC。 适合人群:具备一定电子工程和数字信号处理基础,特别是对DAC设计感兴趣的研究生或研究人员。 使用场景及目标:①适用于研究高精度数模转换技术的学术机构;②为设计高阶过采样delta-sigma DAC提供理论和技术支持;③探索delta-sigma技术在音频和其他高精度应用领域的潜力。 阅读建议:此资源不仅涉及复杂的理论分析,还包括详细的硬件实现步骤,建议读者在理解基本概念的基础上逐步深入,结合Matlab仿真和FPGA实现进行实践,以加深对delta-sigma DAC设计的理解。
cmd-bat-批处理-脚本-弹出对话框.zip
提供一个ARIMA模型的MATLAB代码示例,该代码能够根据用户自身的具体需求灵活调整参数,从而达到预期的分析效果。
cmd-bat-批处理-脚本-倒记时(全屏).zip
ssm+vue图书管理系统全套源码+毕业论文+数据库sql,全套毕设,非常具有参考意义
cmd-bat-批处理-脚本-更改电源管理方式.zip
cmd-bat-批处理-脚本-禁止用XP的图片视频预览功能.zip
i.MX93外设驱动程序,一分价钱一分货,项目代码可顺利编译运行~