首页 技术 正文
技术 2022年11月22日
0 收藏 699 点赞 5,072 浏览 2205 个字

//给一个图。给定起点和终点,仅仅能走图上的最短路

//问最多有多少种走的方法。每条路仅仅能走一次

//仅仅要将在最短路上的全部边的权值改为1。求一个最大流即可

#include<cstdio>

#include<cstring>

#include<iostream>

#include<queue>

#include<vector>

using namespace std ;

const int inf = 0x3f3f3f3f ;

const int maxn = 1010 ;

const int maxm = 1e5+10 ;

int head[maxn] ;

int dis[maxn] ;int n , m ;

int st , en ;int len ;

int nedge ;

int x[maxm] , y[maxm] , z[maxm];

int vis[maxm] ;

struct Edge

{

    int v , w ;

    int next ;

}edge[maxm<<1] ;

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

{

    edge[nedge].v = v ;

    edge[nedge].w = w ;

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

    head[u] = nedge++ ;

}

void spfa()

{

    memset(vis , 0 , sizeof(vis)) ;

    queue<int> que ;

    for(int i = 1;i <= n;i++)

    dis[i] = i == st ?

0 : inf ;

    que.push(st) ;vis[st] = 1;

    while(que.size())

    {

        int u = que.front();que.pop() ;

        vis[u] = 0 ;

        for(int i = head[u];i != -1 ;i = edge[i].next)

        {

            int v = edge[i].v ;

            if(dis[u] + edge[i].w < dis[v])

            {

                dis[v] = dis[u] + edge[i].w ;

                if(!vis[v])

                {

                    que.push(v) ;

                    vis[v] = 1;

                }

            }

        }

    }

}

bool bfs()

{

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

    dis[st] = 0 ;

    queue<int> que ;

    que.push(st) ;

    while(que.size())

    {

        int u = que.front();que.pop() ;

        for(int i = head[u];i != -1 ;i = edge[i].next)

        {

            int v = edge[i].v ;

            if(dis[v] < 0 && edge[i].w > 0)

            {

                dis[v] = dis[u] + 1 ;

                que.push(v) ;

            }

        }

    }

    if(dis[en] > 0)return true ;

    return false ;

}

int dfs(int u , int mx)

{

    if(u == en)return mx ;

    int ans = 0 , a ;

    for(int i = head[u];i != -1 ;i = edge[i].next)

    {

        int v = edge[i].v ;

        if(dis[v] == dis[u] + 1 && edge[i].w > 0 && (a = dfs(v , min(mx , edge[i].w))))

        {

            mx -= a ;

            ans += a ;

            edge[i].w -= a ;

            edge[i^1].w += a ;

            if(!mx)break;

        }

    }

    if(!ans)dis[u] = -1 ;

    return ans ;

}

int main()

{

    //freopen("in.txt" , "r" , stdin) ;

    int t ;

    scanf("%d" , &t) ;

    while(t–)

    {

        scanf("%d%d" , &n , &m);

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

        nedge = 0 ;len = 0 ;

        while(m–)

        {

            int u , v , w ;

            scanf("%d%d%d" , &u , &v , &w) ;

            if(u != v)

            {

                addedge(u , v , w) ;

                x[len] = u , y[len] = v ,z[len++] = w ;

            }

        }

        scanf("%d%d" , &st , &en) ;

        spfa() ;

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

        nedge = 0 ;

        for(int i = 0;i < len;i++)

        if(dis[x[i]] + z[i] == dis[y[i]])

        {

            addedge(x[i] , y[i] , 1) ;

            addedge(y[i] , x[i] , 0) ;

        }

        int ans = 0 ;

        int res ;

        while(bfs())

          while(res = dfs(st , inf))

            ans += res ;

        printf("%d\n" , ans) ;

    }

    return 0 ;

}

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,992
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,506
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,349
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,134
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,766
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,844