UESTC_排名表 2015 UESTC Training for Graph Theory<Problem I>
I - 排名表
Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others)
暑假前集训已经过了一半了,我们将会把当前排名公布出来。但是此刻秋实大哥却心急火燎,因为他不慎把排名删除了。
一共有n个人参加排名,每个人都有一个名次,没有哪两个人的名次是相同的。现在秋实大哥掌握的一些情报,比如Ai的名次要先于Bi。(编号从1开始)
你能帮秋实大哥恢复出排名表吗?
Input
第一行一个数字 T (T≤10),表示测试数据组数
每组测试数据,第一行两个数 n(1≤n≤200)和 m(0≤m≤40000),接下来m行,每行两个数a和b(1≤a,b≤N),表示a的名次要先于b
Output
对于每组测试数据,输出一行,从1号到n号每个人的名次。
如果有多个解,让编号为1的人的名次尽量小,然后让编号为2的人的名次尽量小,然后让编号为3的人的名次尽量小......
如果没有解,输出−1
Sample input and output
Sample Input | Sample Output |
---|---|
5 |
1 2 3 4 |
Hint
注意可能会有重边
解题思路:
首先,本题正向拓扑排序是不行的,即如果这样建边:
U 的名次先于 V , 即 V 向 U连边
因为题意比较绕,下文都这样叙述:
排名号越高,其名次越低,第一名的排名号是 1 ,它的名次是最高的.
我们按照 v 向 u建边,意思是v的排名号高于u.
无法保证
让编号为1的人的名次尽量小,然后让编号为2的人的名次尽量小,然后让编号为3的人的名次尽量小.
è 让编号为 1 的人的排名号尽量大,然后让编号为 2 的人的排名号尽量大….
我们拓扑排序的顺序是这样的:
每次寻找入度为 0 的点,将排名号赋给这个点,删边,重复.
如果有多个点入度都是 0 呢?我们不假思索的这样想:
我们为了保证题目条件,会使得我们会尽量保证这个点的编号尽量小(这样我们看起来符合了题目条件:编号小的人排名号尽量高),但是我们忽略了,题目要求是先尽力保证编号1的人,之后才是编号2的人….
所以,正向建边是错误的
注意,上面的证明非常不严格(Even it's a mistake),如果小伙伴谁有更好的证明,可在下面回复
#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <vector>
#include <queue>
#define pb push_back
using namespace std;
const int maxn = + ;
int n,m,c[maxn],indig[maxn];
vector<int>E[maxn];
bool existedge[maxn][maxn];
int out[maxn]; bool dfs(int cur)
{
if (c[cur] == )
return true;
c[cur] = -;
for(int i = ; i < E[cur].size() ; ++ i)
{
int nextnode = E[cur][i];
if (c[nextnode] == -)
return false;
if (!c[nextnode] && !dfs(nextnode)) //exist 环
return false;
}
c[cur] = ;
return true;
} typedef struct point
{
int id,indig;
friend bool operator < (const point & x,const point & y)
{
return x.indig < y.indig;
}
point(int id,int indig)
{
this->id = id , this->indig = indig;
}
}; vector<point>v;
bool used[maxn]; void ansset()
{
memset(used,false,sizeof(used));
for(int i = ; i <= n ; ++ i)
v.pb(point(i,indig[i]));
sort(v.begin(),v.end());
int rank = ;
for(int i = ; i <= n ; ++ i)
{
int choose = v[].id;
int pos = ;
while( pos < v.size() && !v[pos].indig)
choose = max(choose,v[pos++].id);
out[choose] = n - rank++;
used[choose] = true;
for(int i = ; i < E[choose].size() ; ++ i)
indig[E[choose][i]]--;
v.clear();
for(int i = ; i <= n ; ++ i)
if(!used[i])
v.pb(point(i,indig[i]));
sort(v.begin(),v.end());
}
} int main(int argc,char *argv[])
{
int Case;
scanf("%d",&Case);
while(Case--)
{
scanf("%d%d",&n,&m);
memset(c,,sizeof(c));
memset(existedge,false,sizeof(existedge));
memset(indig,,sizeof(indig));
while(m--)
{
int u,v;
scanf("%d%d",&u,&v);
if (existedge[v][u])
continue;
E[v].pb(u);
existedge[v][u] = true;
indig[u] ++;
}
int ans = ;
for(int i = ; i <= n ; ++ i)
if (!dfs(i))
{
ans = ;
break;
}
if (!ans)
printf("-1\n");
else
{
v.clear();
ansset();
for(int i = ; i <= n ; ++ i)
i == ? printf("%d",out[i]) : printf(" %d",out[i]);
printf("\n");
}
for(int i = ; i <= n ; ++ i)
E[i].clear();
}
return ;
}
UESTC_排名表 2015 UESTC Training for Graph Theory<Problem I>的更多相关文章
- UESTC_传输数据 2015 UESTC Training for Graph Theory<Problem F>
F - 传输数据 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
- UESTC_方老师和农场 2015 UESTC Training for Graph Theory<Problem L>
L - 方老师和农场 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
- UESTC_王之盛宴 2015 UESTC Training for Graph Theory<Problem K>
K - 王之盛宴 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
- UESTC_小panpan学图论 2015 UESTC Training for Graph Theory<Problem J>
J - 小panpan学图论 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) S ...
- UESTC_韩爷的情书 2015 UESTC Training for Graph Theory<Problem H>
H - 韩爷的情书 Time Limit: 6000/2000MS (Java/Others) Memory Limit: 262144/262144KB (Java/Others) Subm ...
- UESTC_树上的距离 2015 UESTC Training for Graph Theory<Problem E>
E - 树上的距离 Time Limit: 2000/1000MS (Java/Others) Memory Limit: 262143/262143KB (Java/Others) Subm ...
- UESTC_邱老师的脑残粉 2015 UESTC Training for Graph Theory<Problem D>
D - 邱老师的脑残粉 Time Limit: 12000/4000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Sub ...
- UESTC_秋实大哥与时空漫游 2015 UESTC Training for Graph Theory<Problem C>
C - 秋实大哥与时空漫游 Time Limit: 4500/1500MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Su ...
- UESTC_秋实大哥带我飞 2015 UESTC Training for Graph Theory<Problem B>
B - 秋实大哥带我飞 Time Limit: 300/100MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
随机推荐
- ssh秘钥交换详解与实现 diffie-hellman-group-exchange-sha
ssh的DH秘钥交换是一套复合几种算法的秘钥交换算法.在RFC4419中称为diffie-hellman-groupX-exchange-shaX 的算法(也有另一种单纯的 rsaX-shaX 交换算 ...
- 构建一个基于 Spring 的 RESTful Web Service
本文详细介绍了基于Spring创建一个“hello world” RESTful web service工程的步骤. 目标 构建一个service,接收如下HTTP GET请求: http://loc ...
- dom4j解析接口使用SOAP传递的xml
xml 文件的格式类型: <?xml version="1.0" encoding="utf-8"?> <SOAP-ENV:Envelope ...
- unity3d 学习笔记(一)
操作:按下shit 点击坐标轴中心 切换透视图 动画烘焙的概念:相当于把原来的控制器动画或者IK(骨骼)动画所有塌陷为逐帧动画,导出的时候必须选这一项 着色器:从技术的角度来看,着色器是渲染器的一个部 ...
- BNU10806:请在此处签到
每年圣诞,ZUN都会邀请很多人到幻想乡举行联欢,今年也不例外.在联欢前,所有人需要在自己的昵称旁签到(签全名),以示出席.然后ZUN 会把大家的签到表保存下来作为纪念,以激励来年努力工作. 昵称: ...
- HTML 5 视频使用
视频格式 当前,video 元素支持三种视频格式: 格式 IE Firefox Opera Chrome Safari Ogg No 3.5+ 10.5+ 5.0+ No MPEG 4 9.0+ No ...
- How to build UDK2015?
UDK2015 is a stable release of portions of the EDKII project. 本文记录在Win7下用VS2012 编译UDK2015的过程. Step1, ...
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
0.表空间 SQL>select username,default_tablespace from user_users; 查看当前用户的角色 SQL>select * from user ...
- 树状jquery导航条
$(function () { $(".leftsecoundtitle").css({ "display": "none" ...
- java socket报文通信(二)报文的封装
昨天我们谈了怎么建立socket通信的服务端和客户端,今天我们就来谈一谈怎么封装报文. 什么是报文这里我就不在阐述了,不清楚的朋友可以自己去查资料.我们今天要谈的报文主要友以下几个部分组成: 3位同步 ...