zoukankan      html  css  js  c++  java
  • 图存储-前向星

    //前向星是将所有的边进行编号,每个节点u的边集合通过head[u]来找到u的第一条边,
    //再通过next[head[u]]依次遍历节点u的所有边。
    int head[maxn]; 
    int to[maxn*2];
    int next[maxn*2];
    int cnt = 0;//边的编号 
     
    memset(head, -1, sizeof(head));
     
    inline void add(int x,int y){
    to[cnt]=y,next[cnt]=head[x],head[x]=cnt++;
    to[cnt]=x,next[cnt]=head[y],head[y]=cnt++;
    
    }
     
    inline void dfs(int u)
    {
       int i;
        //从节点u的第一条边开始,遍历与u相连的所有边
        for(i=head[u];i!=-1;i=next[i])  
        {  
            dfs(to[i]);
        }
    }
    /*
    head[i]:    以i为节点的边集的第一条边编号
    next[i]:编号为i的边集中的下一条边编号,特定节点u的边的编号连成一个链表
    to[i]:编号为i的边的终点
    */


    //另一种实现
    #include <iostream>
    #include <cstdio>
    using namespace std;
    const int maxn = 100;
    const int maxm = 100000;
    typedef struct edgenode {
        int to; //边的终点
        int next; //当前下一条边的编号
        int w;  //边的权值
    }edgenode;
    int head[maxn]; //head[i]存放已i为起点的第一条边
    edgenode edge[maxm];
    int edgenum = 1;
    int n = 0, m = 0;
    int init() {
        edgenum = 1;
        memset(head, 0, sizeof(head));//chu shi hua 0;
        return 0;
    }
    int outputmap(){
        for (int i = 1; i <= n; i++) {
            for (int k = head[i]; k != 0; k = edge[k].next) {
                printf("(%d --- > %d) == %d
    ", i, edge[k].to, edge[k].w);
            }
        }
        return 0;
    }
    int main() {
        init();
        int a = 0, b = 0, c = 0;
        while (scanf("%d%d", &n, &m) == 2) {
            for (int i = 0; i < m; i++) {
                scanf("%d%d%d", &a, &b, &c);
                edge[edgenum].to = b;
                edge[edgenum].w = c;
                edge[edgenum].next = head[a];
                head[a] = edgenum;
                edgenum++;
                edge[edgenum].to = a;
                edge[edgenum].w = c;
                edge[edgenum].next = head[b];
                head[b] = edgenum;
                edgenum++;
            }
            outputmap();
            init();
        }
        return 0;
    }

  • 相关阅读:
    C#使用Json
    JQuery AJAX介绍
    封装一个自己的 Ajax小框架
    AJAX跨域实现
    AJAX 一些常用方法
    完整的 AJAX 写法(支持多浏览器)
    AJAX 简单上手
    利用反射生成SQL语句
    访问Access数据库(有多个数据库时 体现多态)
    DataTable操作(建表,建行,建列,添加数据)
  • 原文地址:https://www.cnblogs.com/OUSUO/p/3805699.html
Copyright © 2011-2022 走看看