解題思路:拓撲排序+優先佇列,每次找入度為零時的點的時候且值最小的。。。我覺得題目有點問題,剛開始寫的時候,以為樣例的答案是1 4 2 3,畢竟1和4沒輸過啊。。。結果去看了樣例一眼,傻了。

#include<iostream>
#include<algorithm>
#include<queue>
#include<cstring>
#include<vector>
#define maxn 100006
using namespace std;
struct node
{
    int w;
    int to;
    int next;
}edge[maxn];
int cnt;
int visit[maxn];
int head[maxn];
int n,m,seq[maxn];//存點用;
int indeg[maxn];
int indegree[maxn];//算入度用的集合;
void add(int u,int v)//鏈式前向星存圖;
{
    edge[cnt].to=v;
    edge[cnt].next=head[u];
    head[u]=cnt++;
}
int topu()
{
    priority_queue<int,vector<int>,greater<int> >q;
    for(int i=1;i<=n;i++)
    {
        indeg[i]=indegree[i];
        if(indeg[i]==0)
            q.push(i);
    }
    int k=0;
    bool res=false;
    while(!q.empty())
    {
        if(q.size()!=1)//每次入度為零的只能有一個,不然有其他路徑;
            res=true;
        int u=q.top();
        q.pop();
        seq[k++]=u;//seq為排好的順序;
        //cout<<u<<" ";
        for(int i=head[u];i!=-1;i=edge[i].next)
        {
            int v=edge[i].to;
            indeg[v]--;
            if(indeg[v]==0)
            {
                q.push(v);
            }
        }
    }
    return k;
}
int main()
{
    int x,y;
    while(cin>>n>>m)
    {
        memset(head,-1,sizeof(head));
        memset(indeg,0,sizeof(indeg));
        memset(indegree,0,sizeof(indegree));
        for(int i=1;i<=m;i++)
        {
            cin>>x>>y;
            add(x,y);
            indegree[y]++;
        }
        int z=topu();
        for(int i=0;i<z;i++)
        {
            cout<<seq[i];
            if(i<=z-2)
            cout<<" ";
        }
        cout<<endl;
    }
    return 0;
}