版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/m0_38083668/article/details/83050646
题目:旅行计划
解析:
复习一下拓扑排序
代码:
#include <bits/stdc++.h>
using namespace std;
const int Max=100010;
int n,m,sum,tot=1,h,size;
int first[Max],du[Max],ans[Max],p[Max];
struct shu{int to,next;};
shu edge[Max<<2];
inline int get_int()
{
int x=0,f=1;
char c;
for(c=getchar();(!isdigit(c))&&(c!='-');c=getchar());
if(c=='-') f=-1,c=getchar();
for(;isdigit(c);c=getchar()) x=(x<<3)+(x<<1)+c-'0';
return x*f;
}
inline void print(int x)
{
if(x>9) print(x/10);
putchar('0'+x%10);
}
inline void build(int x,int y)
{
edge[++size].next=first[x];
first[x]=size;
edge[size].to=y;
}
inline void topsort()
{
queue<int>q;
for(int i=1;i<=n;i++) if(!du[i]) q.push(i);
while(sum<n)
{
h=0;
while(q.size())
{
int point=q.front();q.pop();
du[point]=1e9,p[++h]=point,ans[point]=tot,sum++;
}
for(int i=1;i<=h;i++)
for(int u=first[p[i]];u;u=edge[u].next)
{
int to=edge[u].to;
du[to]--;
if(!du[to]) q.push(to);
}
tot++;
}
}
int main()
{
n=get_int(),m=get_int();
for(int i=1;i<=m;i++)
{
int x=get_int(),y=get_int();
build(x,y),du[y]++;
}
topsort();
for(int i=1;i<=n;i++) print(ans[i]),putchar('\n');
return 0;
}