当前位置: 首页>>代码示例>>C++>>正文


C++ graph_t::size方法代码示例

本文整理汇总了C++中graph_t::size方法的典型用法代码示例。如果您正苦于以下问题:C++ graph_t::size方法的具体用法?C++ graph_t::size怎么用?C++ graph_t::size使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在graph_t的用法示例。


在下文中一共展示了graph_t::size方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: dijkstra_shortest_path

dists_t dijkstra_shortest_path(graph_t g, vert_t s) {
    set<pair<dist_t, vert_t> > q; // implicit ordering by distance
    
    // ps_t ps(g.size(), -1);
    
    dists_t dists(g.size(), dist_infty);
    dists[s] = 0;
    
    q.insert(make_pair(dists[s], s));
    while( !q.empty() ) {
        dist_t dist = q.begin()->first;
        vert_t v = q.begin()->second;
        q.erase( q.begin() ); // pop first
        
        for(int i=0; i<g[v].size(); i++) {
            vert_t t = g[v][i].to;
            dist_t d_with = dist + g[v][i].len;
            
            if( d_with < dists[t] ) { // relax
                q.erase( make_pair(dists[t], t) );
                q.insert( make_pair(d_with, t) );
                dists[t] = d_with;
                // ps[t] = v;
            }
        }
    }
    
    return dists;
}
开发者ID:apirogov,项目名称:icpc-tcr,代码行数:29,代码来源:dijkstra.cpp

示例2: bfs

path_ps_t bfs( graph_t g, capmat_t caps, vert_t s, vert_t t ) {
    path_ps_t ps( g.size(), -1 ); // parents
    ps[s] = s;
    queue<vert_t> q;
    q.push(s);
    while( !q.empty() ) {
        vert_t u = q.front(); q.pop();
        if( u == t ) return ps;
        for( int i=0; i<g[u].size(); i++ ) {
            vert_t v = g[u][i];
            if( ps[v] < 0 && caps[u][v] > 0 ) {
                ps[v] = u;
                q.push(v);
            }
        }
    }
}
开发者ID:apirogov,项目名称:icpc-tcr,代码行数:17,代码来源:EdmondsKarp.cpp

示例3: min_cost_flow

// solve minimun cost flow problem from s to t to flow f
double min_cost_flow(graph_t &graph, int s, int t, int f, bool display_progress)
{
    int V = graph.size(); // number of vertices
    vector<double> h(V, 0); // potential
    vector<double> dist(V, INF); // minimum distance from s
    vector<int> prevv(V, 0); // previous vertex
    vector<int> preve(V, 0); // previous edge

    double ret = 0;

    Progress progress(f, display_progress);
    while (f > 0)
    {
        if (Progress::check_abort())
            return RET_ABORTED;

        // Dijkstra algorithm
        priority_queue<Pair, vector<Pair>, greater<Pair> > que;
        fill(dist.begin(), dist.end(), INF);
        dist[s] = 0;
        que.push(Pair(0, s));
        while (!que.empty())
        {
            Pair p = que.top();
            int v = p.second;
            double d = p.first;
            que.pop();
            if (dist[v] < d)
                continue;
            for (int i = 0; i < (int)graph[v].size(); i++)
            {
                edge_t &e = graph[v][i];
                d = dist[v] + e.cost + h[v] - h[e.to];
                if (dist[v] > d) d = dist[v]; // for rounding error
                if (e.capacity > 0 && dist[e.to] > d)
                {
                    dist[e.to] = d;
                    prevv[e.to] = v;
                    preve[e.to] = i;
                    que.push(Pair(dist[e.to], e.to));
                }
            }
        }

        // no solution
        if (dist[t] == INF)
            return RET_NO_SOLUTION;

        // update potential
        for (int v = 0; v < V; v++)
            h[v] += dist[v];

        int d = f;
        for (int v = t; v != s; v = prevv[v])
            d = min(d, graph[prevv[v]][preve[v]].capacity);
        f -= d;
        progress.increment(d);

        ret += d * h[t];
        for (int v = t; v != s; v = prevv[v])
        {
            edge_t &e = graph[prevv[v]][preve[v]];
            e.capacity -= d;
            graph[v][e.rev].capacity += d;
        }
    }
    return ret;
}
开发者ID:mkanai,项目名称:ccmatch,代码行数:69,代码来源:ccmatch.cpp

示例4: allocPoint

int DFA::allocPoint()
{
    int newNode = m_graph.size();
    m_graph.emplace_back();
    return newNode;
}
开发者ID:hjliang,项目名称:ccompiler,代码行数:6,代码来源:regex.cpp


注:本文中的graph_t::size方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。