cdoj 1150 排名表 拓扑排序

排名表

Time Limit: 20 Sec

Memory Limit: 256 MB

题目连接

http://acm.uestc.edu.cn/#/problem/show/1150

Description

暑假前集训已经过了一半了,我们将会把当前排名公布出来。但是此刻秋实大哥却心急火燎,因为他不慎把排名删除了。

一共有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

5
4 0
4 1
1 1
4 2
1 2
2 1
4 1
2 1
4 1
3 2

Sample Output

1 2 3 4
-1
-1
2 1 3 4
1 3 2 4

HINT

 

题意

 

题解:

逆向拓扑排序,注意,这个是输出每个的排名,而不是按着排名顺序输出人

代码:

 

//qscqesze
#include <cstdio>
#include <cmath>
#include <cstring>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <sstream>
#include <queue>
#include <typeinfo>
#include <fstream>
#include <map>
#include <stack>
typedef long long ll;
using namespace std;
//freopen("D.in","r",stdin);
//freopen("D.out","w",stdout);
#define sspeed ios_base::sync_with_stdio(0);cin.tie(0)
#define maxn 200001
#define mod 10007
#define eps 1e-9
int Num;
char CH[20];
//const int inf=0x7fffffff;   //нчоч╢С
const int inf=0x3f3f3f3f;
/*inline void P(int x)
{Num=0;if(!x){putchar('0');puts("");return;}while(x>0)CH[++Num]=x%10,x/=10;while(Num)putchar(CH[Num--]+48);puts("");
}
*/
inline ll read()
{ll x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}return x*f;
}
inline void P(int x)
{Num=0;if(!x){putchar('0');puts("");return;}while(x>0)CH[++Num]=x%10,x/=10;while(Num)putchar(CH[Num--]+48);puts("");
}
//**************************************************************************************int head[maxn];
int top;
int d[maxn];
priority_queue<int>q;
struct edge
{int v,next;
}e[maxn];
int cnt;
int ans[maxn];
int ans1[maxn];
int n,m;
void insert(int u,int v)
{e[cnt].v=v;e[cnt].next=head[u];head[u]=cnt;cnt++;
}void solve(int x)
{q.pop();ans[++top]=x;for(int i=head[x];i>=0;i=e[i].next){d[e[i].v]--;if(d[e[i].v]==0)q.push(e[i].v);}
}int main()
{//freopen("test.txt","r",stdin);int t=read();while(t--){n=read(),m=read();cnt=top=0;memset(head,-1,sizeof(head));memset(d,0,sizeof(d));for(int i=1;i<=m;i++){int u=read(),v=read();insert(v,u);d[u]++;}for(int i=1;i<=n;i++)if(!d[i])q.push(i);while(!q.empty()){solve(q.top());}if(top!=n)printf("-1\n");else{int cnt3=1;int first=1;for(int i=n;i;i--){ans1[ans[i]]=cnt3++;}for(int i=1;i<=n;i++){if(i==1)printf("%d",ans1[i]);elseprintf(" %d",ans1[i]);}printf("\n");}}return 0;
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/400214.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c++ 连接两个字符串实现代码 实现类似strcat功能(转)

想实现strcat功能&#xff0c;直接网上找一个。 第一种&#xff1a; #include "stdafx.h" #include<iostream> using namespace std; int _tmain(int argc, _TCHAR* argv[]) { char s1[60]"kingbaby"; char *s2"hello"; int i0;int …

使用ajax完成python flask前端与后台数据的交互

https://blog.csdn.net/omodao1/article/details/83049960

Linux内存卡(SD卡、TF卡)作为Swap交换空间

目录平台&#xff1a;华硕 Thinker Edge R 瑞芯微 RK3399Pro 固件版本&#xff1a;Tinker_Edge_R-Debian-Stretch-V1.0.4-20200615 编译ORB-SLAM3时内存不足报错&#xff0c;专门买来一个32G的内存卡&#xff0c;设成swap试试。 插上内存卡&#xff0c;使用如下命令查看&#…

mysqldumper

介绍MySQL自身的mysqldump工具支持单线程工作&#xff0c;依次一个个导出多个表&#xff0c;没有一个并行的机&#xff0c;这就使得它无法迅速的备份数据。mydumper作为一个实用工具&#xff0c;能够良好支持多线程工作&#xff0c;可以并行的多线程的从表中读入数据并同时写到…

第二阶段冲刺进程6

今天是一个值得纪念的日子&#xff0c;为什么呢&#xff0c;因为我们的程序已经基本做出来啦~ 因为考虑到sqlite还是比较麻烦&#xff0c;主要是没有学过&#xff0c;很多东西可能很简单&#xff0c;但就是不会写&#xff0c;所以我们用了读取txt文件里的单词&#xff0c;相当于…

机器学习算法及应用领域相关的中国大牛

李航&#xff1a;http://research.microsoft.com/en-us/people/hangli/&#xff0c;是MSRA Web Search and Mining Group高级研究员和主管&#xff0c;主要研究领域是信息检索&#xff0c;自然语言处理和统计学习。近年来&#xff0c;主要与人合作使用机器学习方法对信息检索中…

python和flask中返回JSON数据

https://blog.csdn.net/matengbing/article/details/78653591

【STC15库函数上手笔记】6、ADC

目录硬知识ADC初始化函数ADC电源控制函数ADC查询转换函数测试main.c实验现象STC实验箱4 IAP15W4K58S4 Keil uVision V5.29.0.0 PK51 Prof.Developers Kit Version:9.60.0.0 硬知识 摘自《STC库函数使用参考》 ADC初始化函数 ADC_Inilize ADC_InitTypeDef的定义见于文件&q…

python3.x : 安装opencv

原文链接&#xff1a; http://blog.csdn.net/keith_bb/article/details/65447707?locationNum6&fps1 ———————————————————————————— 1.OpenCV下载 首先创建一个空的文件夹&#xff0c;进入文件夹执行如下命令,如我创建的文件夹是opencv-pytho…

NEWS - InstallShield 2015 正式发布

如果您需要为Windows应用程序创建安装&#xff0c;InstallShield便是您的最佳解决方案。在为桌面、服务器、云、Web和虚拟环境构建可靠的Windows Installer (MSI)和InstallScript安装程序时&#xff0c;InstallShield让开发团队能轻松地提高敏捷性、灵活性和协作性。 美国时间2…

【RK3399Pro学习笔记】十七、Debian安装ORB-SLAM3和单目demo的运行

目录安装OpenCV 3注意事项安装Glew安装Pangolin安装boost安装Eigen 3安装ORB_SLAM3试用平台&#xff1a;华硕 Thinker Edge R 瑞芯微 RK3399Pro 固件版本&#xff1a;Tinker_Edge_R-Debian-Stretch-V1.0.4-20200615 参考资料&#xff1a; 【入门必看】视觉惯性SLAM“灭霸”&am…

Flask设置返回json格式数据

https://blog.csdn.net/angus_17/article/details/80455838 from flask import Flask, jsonifyapp Flask(__name__)app.route(/) def root():t {a: 1,b: 2,c: [3, 4, 5]}return jsonify(t)if __name__ __main__:app.debug Trueapp.run()问题描述 在Flask中直接返回list或d…

C#多线程学习之:Monitor类

关于对C#多线程类Monitor的理解 1、对线程的理解 围绕着锁周围的线程可以分为以下三类&#xff1a; l 拥有锁的线程&#xff1a;只有一个 l 就绪队列&#xff1a;只有就绪队列里的线程才有机会在锁被释放时去获取锁。 l 等待队列&#xff1a;没有资格去获取锁。 2、Monitor.…

形参的一种特殊写法

形参的一种特殊写法 import java.lang.*; import javax.swing.*; import javax.swing.text.IconView;public class Xample_3 {public void Str (String...strings){for(int i0; i<strings.length;i){System.out.println(strings[i]);}}public void Int(int...is){int isall …

【0.96寸 OLED屏实现1500Fps的帧率】STM32 软件、硬件SPI、I2C驱动总结

目录SPI版OLED SPI 端口定义七针OLED引脚定义六针OLED引脚定义软件SPI硬件SPI启用DMA帧率测试I2C 版软件I2C硬件I2CDMASTM32F103VET6 STM32 Cube IDE SPI版 OLED SPI 端口定义 本节引自STM32驱动0.96寸OLED液晶屏(12864液晶屏) —— 小牧同学 两种屏幕的引脚数不一样&#x…

Datatables 给行绑定选中事件

//给行绑定选中事件$(#table_id_example tbody).on( click, tr, function () {if ($(this).hasClass(selected)) {$(this).removeClass(selected);}else {table.$(tr.selected).removeClass(selected);$(this).addClass(selected);}} );

网络工程师第五站-有线、无线同网段混合组网(多FAT案例)

本案例中用到的设备&#xff1a;路由器&#xff1a;cisco 2851交换机&#xff1a;cisco WS-C3750G-12S &#xff08;HX&#xff09;&#xff0c;接入&#xff1a;WS-C2960-48TC-LAP &#xff1a; 华为AP3010dn-AGN3750G 作为该网络核心交换机HX&#xff0c;前面的接口&#xff…

Jstat使用样例

jstat -gc pid //以字节形式展现 jstat -gcutil pid //以百分比形式展现 jstat -class pid //类加载和卸载状况 jstat -compilier pid //查看Jit编译的方法数及失败情况 jstat -printcompilation 4672 //打印最近编译的一个方法 转载于:https://www.cnblogs.com/ironroot/p…

JAVA静态和非静态内部类

JAVA静态和非静态内部类 一直对java的静态和非静态内部类的东东理解不清楚&#xff0c;今天测试了一下&#xff0c;下面把测试结果记录一下&#xff0c;加深印象。用于以后查找。 直接上代码。 Java代码 package com.test.xml; /** * author <a href"mailto:dq201…

便宜的手机图传遥控模块

目录测试程序FHDFPV.cFHDFPV.h应用效果STM32F103RC STM32 Cube IDE 大一时买的&#xff0c;当时是50元左右&#xff0c;很便宜&#xff0c;安卓上位机为FHDFPV 我买的型号波特率约为18464&#xff0c; 实测帧头为102&#xff0c;帧尾为153&#xff0c;前四个数为左右遥感对应…