眾所周知, tt 是一位重度愛貓人士,他有乙隻神奇的魔法貓。
有一天,tt 在 b 站上**貓貓的比賽。一共有 n 只貓貓,編號依次為1,2,3,…,n進行比賽。比賽結束後,up
主會為所有的貓貓從前到後依次排名並發放愛吃的小魚幹。不幸的是,此時 tt
的電子裝置遭到了宇宙射線的降智打擊,一下子都連不上網了,自然也看不到最後的頒獎典禮。
不幸中的萬幸,tt 的魔法貓將每場比賽的結果都記錄了下來,現在他想程式設計序確定字典序最小的名次序列,請你幫幫他。
input
輸入有若干組,每組中的第一行為二個數n(1<=n<=500),m;其中n表示貓貓的個數,m表示接著有m行的輸入資料。接下來的m行資料中,每行也有兩個整數p1,p2表示即編號為 p1 的貓貓贏了編號為 p2 的貓貓。
output
給出乙個符合要求的排名。輸出時貓貓的編號之間有空格,最後一名後面沒有空格!
其他說明:符合條件的排名可能不是唯一的,此時要求輸出時編號小的隊伍在前;輸入資料保證是正確的,即輸入資料確保一定能有乙個符合要求的排名。
sample input
4 3
1 22 3
4 3
sample output1 2 4 3
該題用拓撲排序解決,貓貓之間的勝負關係構成一張有向無環圖。p1贏了p2意味著節點p1到p2之間有一條邊指向p2。
由於題目要求輸出字典序最小的排名,需要維護乙個小根堆(優先順序佇列),每次取編號最小的點出隊。
優先順序佇列預設大根堆,丟負數變成小根堆
#include
#include
#include
#include
using
namespace std;
int n,m,p1,p2;
vector<
int> v[
505]
;int a[
505]
;void
toposort()
while
(!q.
empty()
)printf
("%d"
,u);if(
!q.empty()
)printf
(" ");
}printf
("\n");
}int
main()
while
(m--
)toposort()
;}return0;
}
week8 B 貓貓向前衝(拓撲排序)
一 題目描述 眾所周知,tt 是一位重度愛貓人士,他有乙隻神奇的魔法貓。有一天,tt 在 b 站上 貓貓的比賽。一共有 n 只貓貓,編號依次為1,2,3,n進行比賽。比賽結束後,up 主會為所有的貓貓從前到後依次排名並發放愛吃的小魚幹。不幸的是,此時 tt 的電子裝置遭到了宇宙射線的降智打擊,一下子...
week8 B 貓貓向前衝
眾所周知,tt 是一位重度愛貓人士,他有乙隻神奇的魔法貓。有一天,tt 在 b 站上 貓貓的比賽。一共有 n 只貓貓,編號依次為1,2,3,n進行比賽。比賽結束後,up 主會為所有的貓貓從前到後依次排名並發放愛吃的小魚幹。不幸的是,此時 tt 的電子裝置遭到了宇宙射線的降智打擊,一下子都連不上網了,...
WEEK 8 B 貓貓向前衝
眾所周知,tt 是一位重度愛貓人士,他有乙隻神奇的魔法貓。有一天,tt 在 b 站上 貓貓的比賽。一共有 n 只貓貓,編號依次為1,2,3,n進行比賽。比賽結束後,up 主會為所有的貓貓從前到後依次排名並發放愛吃的小魚幹。不幸的是,此時 tt 的電子裝置遭到了宇宙射線的降智打擊,一下子都連不上網了,...