题意与分析

2018ICPC北京站A题。

题意是这样的,给定若干人的武力值大小(A B的意思是A比B厉害),问到第几行会出现矛盾。

这题不能出现思维定势,看到矛盾就是矛盾并查集——A>B、A>C是不能推出B>C或者B<C的。相反,大于小于是一种偏序关系,是可以建立有向图的。那么,如果这个有向图中出现了环,就是矛盾的。

问题于是转化为有向图判环问题,这里简单说一下有向图和无向图的判环方法。

a) 无向图

  1. 删除所有度<=1的顶点及相关的边,并将另外与这些边相关的其它顶点的度减一。
  2. 将度数变为1的顶点排入队列,并从该队列中取出一个顶点重复步骤一。

最后如果最后还有未删除顶点,则存在环,否则没有环。

b) 有向图

对于n个节点的有向图,令cnt = 0。

  1. 将所有入度为0的节点入队;
  2. 将队头节点v出队,cnt++,直至队列为空;
  3. 遍历与v相连的节点,并将相连节点的入度减一,若入度变为0,将此节点入队。

最后,若cnt==n,访问到所有节点,完成拓扑排序(这是出队顺序的意义),否则,存在环。

代码

/* ACM Code written by Sam X or his teammates.
* Filename: a.cpp
* Date: 2018-11-17
*/ #include <bits/stdc++.h> #define INF 0x3f3f3f3f
#define PB emplace_back
#define MP make_pair
#define fi first
#define se second
#define rep(i,a,b) for(repType i=(a); i<=(b); ++i)
#define per(i,a,b) for(repType i=(a); i>=(b); --i)
#define ZERO(x) memset(x, 0, sizeof(x))
#define MS(x,y) memset(x, y, sizeof(x))
#define ALL(x) (x).begin(), (x).end() #define QUICKIO \
ios::sync_with_stdio(false); \
cin.tie(0); \
cout.tie(0);
#define DEBUG(...) fprintf(stderr, __VA_ARGS__), fflush(stderr) using namespace std;
using pi=pair<int,int>;
using repType=int;
using ll=long long;
using ld=long double;
using ull=unsigned long long; const int MAXN=25;
vector<int> G[MAXN];
vector<pi> edges;
void add_edge(int u,int v)
{
edges.PB(u,v);
G[u].PB(edges.size()-1);
}
int vis[MAXN];
int n;
unordered_map<string,int> ma;
vector<string> idx;
int gh(string str)
{
if(ma.find(str)==ma.end())
{
idx.PB(str);
return ma[str]=idx.size()-1;
}
return ma[str];
} bool has_loop()
{
int cnt=0;
queue<int> q;
int deg[MAXN];
ZERO(deg);
rep(i,0,int(edges.size())-1)
{
deg[edges[i].se]++;
}
rep(i,0,idx.size()-1)
if(deg[i]==0)
{
q.push(i);
}
while(!q.empty())
{
//cout<<"Now: "<<q.front()<<endl;
cnt++;
auto now=q.front(); q.pop();
rep(i,0,int(G[now].size())-1)
{
deg[edges[G[now][i]].se]--;
if(deg[edges[G[now][i]].se]==0)
q.push(edges[G[now][i]].se);
}
}
//cout<<cnt<<" and "<<idx.size()<<endl;
return cnt!=idx.size();
}
int
main()
{
while(cin>>n)
{
bool ok=true;
idx.clear();
ma.clear();
rep(i,0,20) G[i].clear();
edges.clear();
rep(i,1,n)
{
string stra,strb;
cin>>stra>>strb;
if(!ok) continue;
int u=gh(stra), v=gh(strb);
//cout<<"Add: "<<u<<" "<<v<<endl;
add_edge(u,v);
if(has_loop())
{
cout<<stra<<" "<<strb<<endl;
ok=false;
}
}
if(ok) cout<<0<<endl;
} return 0;
}

「日常训练」Jin Yong’s Wukong Ranking List(HihoCoder-1870)的更多相关文章

  1. hihoCoder #1870 : Jin Yong’s Wukong Ranking List-闭包传递(递归) (ACM-ICPC Asia Beijing Regional Contest 2018 Reproduction A) 2018 ICPC 北京区域赛现场赛A

    P1 : Jin Yong’s Wukong Ranking List Time Limit:1000ms Case Time Limit:1000ms Memory Limit:512MB Desc ...

  2. 「日常训练」ZgukistringZ(Codeforces Round #307 Div. 2 B)

    题意与分析(CodeForces 551B) 这他妈哪里是日常训练,这是日常弟中弟. 题意是这样的,给出一个字符串A,再给出两个字符串B,C,求A中任意量字符交换后(不限制次数)能够得到的使B,C作为 ...

  3. 「日常训练」 Fire!(UVA-11624)

    与其说是训练不如说是重温.重新写了Java版本的代码. import java.util.*; import java.math.*; import java.io.BufferedInputStre ...

  4. 「日常训练」COMMON 约数研究(HYSBZ-1968)

    题意与分析 感谢https://www.cnblogs.com/Leohh/p/7512960.html的题解.这题话说原来不在我的训练范围,正好有个同学问我,我就拿来做做.数学果然不是我擅长的啊,这 ...

  5. 「日常训练」 Mike and Fun (CFR305D2B)

    题意(CodeForces 548B) 每次对01矩阵中的一位取反,问每次操作后,单列中最长连续1的长度. 分析 非常非常简单,但是我当时训练的时候WA了四次...无力吐槽了,人间 不值得.jpg 代 ...

  6. 「日常训练」Common Subexpression Elimination(UVa-12219)

    今天做的题目就是抱佛脚2333 懂的都懂. 这条题目干了好几天,最后还是参考别人的代码敲出来了,但是自己独立思考了两天多,还是有收获的. 思路分析 做这条题我是先按照之前的那条题目(The SetSt ...

  7. 「日常训练」Magic Stones(CodeForces-1110E)

    题意 给定两个数组c和t,可以对c数组中的任何元素变换\(c_i\)​成\(c_{i+1}+c_{i-1}-c_i\)​,问c数组在若干次变换后能否变换成t数组. 分析 这种魔法题目我是同样的没做过. ...

  8. 「日常训练」Jongmah(Codeforces-1110D)

    题意 你有n个数字,范围[1, m],你可以选择其中的三个数字构成一个三元组,但是这三个数字必须是连续的或者相同的,每个数字只能用一次,问这n个数字最多构成多少个三元组? 分析 根据官方Editori ...

  9. 「日常训练」The Necklace(UVA-10054)

    代码 for(int i=0; i!=n; ++i) { int u = cin.nextInt(); int v = cin.nextInt(); edges.add(new Edge(u,v)); ...

随机推荐

  1. Mybatis 和Spring整合之mapper代理开发

    F:\1ziliao\mybatis\代码 1.1 SqlMapConfig.xml <?xml version="1.0" encoding="UTF-8&quo ...

  2. localStorage和cookie操作

    localStorage和cookie操作代码: cookie: { isSupportCookie: function() { return navigator.cookieEnabled; }, ...

  3. 使用IPDB调试Python代码

    (转载自:https://xmfbit.github.io/2017/08/21/debugging-with-ipdb/) IPDB是什么?IPDB(Ipython Debugger),和GDB类似 ...

  4. C# DataSet导出Excel

    //多个DataSet导出Excel文件 public static void DataSetToExcel(DataSet p_ds,string strSavePath) { ;//多个DataS ...

  5. 100个常用的linux命令(转)

    来源:JavaRanger – javaranger.com   http://www.javaranger.com/archives/907 1,echo “aa” > test.txt 和 ...

  6. 【Cmd命令行】基础—findstr与for循环

    Findstr命令 findstr是Window系统自带的命令,用途是查找指定的一个或多个文件文件中包含(或通过参数 /V来控制不包含)某些特定字符串的行,并将该行完整的信息打印出来,或者打印查询字符 ...

  7. Ldap实现AD域认证

    1.java Ldap基础类 package com.common; import java.io.FileInputStream; import java.io.IOException; impor ...

  8. 解决echarts 鼠标悬浮提示 文本提示问题。

    参考文章:https://www.jianshu.com/p/aa585c304660 官方文章样式详解:http://echarts.baidu.com/option.html#tooltip.fo ...

  9. JS 匿名函数或自执行函数总结

    JS引擎在遇到function关键字时做如下两种处理: 1.当语句是以function关键字开头:此时的JS语句解释为函数声明,因此function关键字后面必须要跟函数名字,如果写成匿名函数,则会报 ...

  10. nodejs的安装配置

    Node.js安装及环境配置   一.安装环境 1.本机系统:Windows 10 Pro(64位)2.Node.js:v6.9.2LTS(64位) 二.安装Node.js步骤 1.下载对应你系统的N ...