URAL 1022 Genealogical tree
[报告]
非常非常裸的拓扑排序……
估计网上面随便拉个拓扑排序的程序,把输入改下都可以用。
本来这道题目可以用链表做,但C++的链表我用不来……
[程序]
// TASK: 1022 Genealogical tree
#include <cstdlib>
#include <iostream>
#include <string>
#define N 100
using namespace std;
bool t[N+1][N+1];
long d[N+1];
long n;
inline void init()
{
cin >> n;
memset(d,0,sizeof(d));
memset(t,0,sizeof(t));
for (long i=1;i<=n;i++)
for (long
a;(cin>>a)&&(a>0);d[a]++)
t[i][a]=true;
}
inline void calc()
{
for (long dex=1;dex<=n;dex++)
{
long k=1;
for
(;(k<=n)&&(d[k]>0);k++);
d[k]=1<<30-1;
for (long i=1;i<=n;i++)
if (t[k][i])
d[i]--;
if (dex>1) cout << "
";
cout << k;
}
}
int main(int argc, char *argv[])
{
init();
calc();
//
system("PAUSE");
return
EXIT_SUCCESS;
}

浙公网安备 33010602011771号