@description@

n 个队伍两两之间比赛,保证没有平局。

现在给出 n 个队伍分别的获胜次数,询问这些数据是否合法。

Input

先给出 T(T≤50) 表示数据组数。

对于每组数据给出 n(n≤50000) 表示参赛队伍数。

接下来 n 行,第 i 给出一个整数 ai (0≤ai<n) 表示第 i 个队伍的获胜次数。

Output

对于每组数据,若不合法输出 "The data have been tampered with!",否则输出 "It seems to have no problem."。

Sample Input

2

3

2

1

0

3

2

2

2

Sample Output

It seems to have no problem.

The data have been tampered with!

Hint:

对于第一组数据,一种可能的情况是队伍 1 战胜队伍 2, 3,队伍 2 战胜队伍 3。

对于第二组数据,不难发现不存在一种可能的胜负情况。

@solution@

竞赛图的判定,有一个叫作兰道定理的东西。

但是我这里不详细讲兰道定理的一般证明方法,只提供我在网上看到的一个有趣的推导。

假如胜者向败者连边,则题目相当于给出竞赛图中所有点的出度,问是否存在合法的图。

考虑给无向完全图的边定向得到竞赛图,我们定向为 u->v 时,u 所需要的出度就会少 1。

这会让我们联想起混合图欧拉路中,也是通过给无向边定向调整入度出度。于是联想到网络流。

考虑如下的建模:

从 s 向 n*(n-1) 条边连容量为 1 的边;假如第 i 条边为 (u, v),则 i 向 u 和 v 各连一条容量为 1 的边;最后 n 个顶点向 t 连容量为 a[i] 的边。

假如这个网络流能够满流,则对应原题目中的合法。

但是显然我们直接跑是跑不了的,考虑怎么样才能直接判定。

如果我们将 n 个顶点每一个点拆成 a[i] 个点,则问题可以转为二分图完美匹配的判定性问题,于是就可以引入 hall 定理。

考虑从左边选出一个集合对应的右边的邻集意义是什么,不难发现其实是从原图中选出一个边集,每条边连接的原图中的点的集合。

hall 定理要求邻集必须比当前集合大。反过来,我们考虑给定一个邻集(即对应原图中的点集),能够得到的最大的当前集合有多大——其实就是边集在原图中形成完全图时最大。

于是,我们可以在本题中将 hall 定理等价地推为 \(\frac{|S|*(|S|-1)}{2} \le \sum_{i\in S}a[i]\),对于原图中任意一个点集 S 都要满足。

注意到左边只与 S 的大小有关,我们只需要考虑 S 同等大小的情况下 \(\sum_{i\in S}a[i]\) 的最小值。贪心地想这个最小值一定是 a 中前 |S| 小的加起来。

于是:只需要将 a 排好序,对于每一个 i,如果满足 a[1] + a[2] + ... + a[i] >= i*(i-1)/2 即有解。

当然因为要求完美匹配,所以左右大小应该相等,即应该有 a[1] + a[2] + ... + a[n] = n*(n-1)/2。

其实上面的判别式就是兰道定理。

@accepted code@

#include<cstdio>
#include<algorithm>
using namespace std;
typedef long long ll;
const int MAXN = 50000;
int a[MAXN + 5], n;
void solve() {
scanf("%d", &n);
for(int i=1;i<=n;i++)
scanf("%d", &a[i]);
sort(a + 1, a + n + 1);
ll sum = 0;
for(int i=1;i<=n;i++) {
sum += a[i];
if( sum < 1LL*i*(i-1)/2 ) {
puts("The data have been tampered with!");
return ;
}
}
if( sum == 1LL*n*(n-1)/2 )
puts("It seems to have no problem.");
else puts("The data have been tampered with!");
}
int main() {
int T; scanf("%d", &T);
while( T-- ) solve();
}

@details@

至于兰道定理真正的证明。。。没有必要记吧。。。记忆一个 hall 定理已经够累了。。。

@hdu - 5503@ EarthCup的更多相关文章

  1. HDOJ 2111. Saving HDU 贪心 结构体排序

    Saving HDU Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  2. 【HDU 3037】Saving Beans Lucas定理模板

    http://acm.hdu.edu.cn/showproblem.php?pid=3037 Lucas定理模板. 现在才写,noip滚粗前兆QAQ #include<cstdio> #i ...

  3. hdu 4859 海岸线 Bestcoder Round 1

    http://acm.hdu.edu.cn/showproblem.php?pid=4859 题目大意: 在一个矩形周围都是海,这个矩形中有陆地,深海和浅海.浅海是可以填成陆地的. 求最多有多少条方格 ...

  4. HDU 4569 Special equations(取模)

    Special equations Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u S ...

  5. HDU 4006The kth great number(K大数 +小顶堆)

    The kth great number Time Limit:1000MS     Memory Limit:65768KB     64bit IO Format:%I64d & %I64 ...

  6. HDU 1796How many integers can you find(容斥原理)

    How many integers can you find Time Limit:5000MS     Memory Limit:32768KB     64bit IO Format:%I64d ...

  7. hdu 4481 Time travel(高斯求期望)(转)

    (转)http://blog.csdn.net/u013081425/article/details/39240021 http://acm.hdu.edu.cn/showproblem.php?pi ...

  8. HDU 3791二叉搜索树解题(解题报告)

    1.题目地址: http://acm.hdu.edu.cn/showproblem.php?pid=3791 2.参考解题 http://blog.csdn.net/u013447865/articl ...

  9. hdu 4329

    problem:http://acm.hdu.edu.cn/showproblem.php?pid=4329 题意:模拟  a.     p(r)=   R'/i   rel(r)=(1||0)  R ...

随机推荐

  1. 全栈数据工程师养成攻略:Python 基本语法

    全栈数据工程师养成攻略:Python 基本语法 Python简单易学,但又博大精深.许多人号称精通Python,却不会写Pythonic的代码,对很多常用包的使用也并不熟悉.学海无涯,我们先来了解一些 ...

  2. 这些Excel学会了,你做账的效率将大大提高

    这些Excel学会了,你做账的效率将大大提高 这些功能学会了,工作效率将大大提高. 1.excel的快速访问工具栏: 我的快速访问工具栏由左到右主要是"保存"."新建&q ...

  3. mysql_example

    package main import ( "database/sql" "fmt" _ "github.com/go-sql-driver/mysq ...

  4. maven的hibernate4 依赖

    <!-- 添加Hibernate4依赖 --> <dependency> <groupId>org.hibernate</groupId> <ar ...

  5. day18 9.转账汇款案例(1)

  6. Django项目:CRM(客户关系管理系统)--13--05PerfectCRM实现King_admin注册功能获取内存02

    admin_class.model = modelself.registered_sites[app_name][model_name] = admin_class #注册APP #base_admi ...

  7. golang中特殊的标识符

    你会发现在 Go 代码中的几乎所有东西都有一个名称或标识符.另外,Go 语言也是区分大小写的,这与 C 家族中的其它语言相同.有效的标识符必须以字符(可以使用任何 UTF-8 编码的字符或 _)开头, ...

  8. HZOI20190714 T3建造游乐场

    先放作者的正解: 先说g吧,有i个点的话,在其中i-1个点中有$C_{i-1}^{2}$种边,每个边有选和不选两种情况.如果度不是偶数呢?用剩下那个点给他连上呗.如果剩下那个点度数不是偶数呢?这是不可 ...

  9. 【JZOJ4799】【NOIP2016提高A组模拟9.24】我的快乐时代

    题目描述 输入 一行,两个整数l,r . 输出 一行,一个整数,表示第l 天到第r 天的愉悦值的和. 样例输入 64 89 样例输出 1818 数据范围 解法 可以参考数位动态规划的想法. 从个位开始 ...

  10. iOS 9 学习系列:UIStack View

    http://www.cocoachina.com/ios/20150921/13492.html 在 iOS9 中,Apple 引入了 UIStackView,他让你的应用可以通过简单的方式,纵向或 ...