上次比赛的时候有一道题目要用到最小生成树,用动态邻接表存储边的结构,结果MLE。实际上很多次了,没有学会用静态邻接表,吃亏不小。
今天趁着Lost大牛来这请客并教育我一番的劲头下,到它(哦,不,是他)的blog上偷盗了他的邻接表代码,花了一个晚上的时间,自己加上了自己的注释,并且加上了权的情况,终于把它搞懂了!
edge[Index].v = y;
edge[Index].w = w;
edge[Index].next = pre[x]; //保存x起点的上一条边在edge数组中的位置
pre[x] = Index++; //位置更新
}
}
void print()
{
for(int i=1;i<=n;i++)
{
printf("%d/n",i);
for(int j=pre[i];j!=-1;j=edge[j].next)
{
printf(" -> %d value is %d/n",edge[j].v,edge[j].w);
}
//printf("/n");
}
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF && (n!=0 || m!=0))
{
Init();
print();
}
return 0;
}