邻接表是通过枚举所有的顶点,和顶点所能到达的所有的边来表示图的。所以有一个顶点域和边域。

简单表述为

struct Edge

{

  int v, w, next;

}edge[MAXN];

int e, head[MAXN];

void init()

{

  e = 0;

  memset(head, -1, sizeof(head));

}

void add(int u, int v, int w)

{

  edge[e].v = v;

  edge[e].w = w;

  edge[e].next = head[u];

  head[u] = e++;

}

posted on 2013-07-26 07:59  认真的看我  阅读(139)  评论(0编辑  收藏  举报