網路流24題 飛行員配對方案問題

2022-08-03 22:27:21 字數 1452 閱讀 5490

第二次世界大戰時期..

英國皇家空軍從淪陷國徵募了大量外籍飛行員。由皇家空軍派出的每一架飛機都需要配備在航行技能和語言上能互相配合的2 名飛行員,其中1 名是英國飛行員,另1名是外籍飛行員。在眾多的飛行員中,每一名外籍飛行員都可以與其他若干名英國飛行員很好地配合。如何選擇配對飛行的飛行員才能使一次派出最多的飛機。對於給定的外籍飛行員與英國飛行員的配合情況,試設計乙個演算法找出最佳飛行員配對方案,使皇家空軍一次能派出最多的飛機。

對於給定的外籍飛行員與英國飛行員的配合情況,程式設計找出乙個最佳飛行員配對方案,使皇家空軍一次能派出最多的飛機。 

第 1 行是最佳飛行員配對方案一次能派出的最多的飛機數 m。接下來 m 行是最佳飛行員配對方案。每行有 2個正整數 i 和 j,表示在最佳飛行員配對方案中,飛行員 i 和飛行員 j 配對。如果所求的最佳飛行員配對方案不存在,則輸出『no solution!』。

就先從這到基礎題開始吧

沒啥可講的,就是最大二分圖匹配,題面也沒繞什麼彎子。。。

從原點s向所有外籍飛行員連一條容量為1的邊,

老外想看得順眼的英國人連容量無限的邊,

英國人向匯點t連容量為1的邊。。。

跑一遍最大流!

完了

1 #include2 #include3 #include4 #include5

using

namespace

std;

6int

n,m,cnt,st,ed,ans;

7int head[405];8

int cur[405];9

int dis[405

];10

int pre[405

];11

int usd[405

];12

struct

edgeedge[400005

];18

void addedge(int u,int v,int

f)30

void

init()

33int

bfs()47}

48}49return dis[ed]!=0x3f3f3f3f;50

}51int dfs(int u,int

flw)65}

66return

all;67}

68int

dinic()

74return

ret;75}

76int

main()

85for(int i=1;i<=m;i++)

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

91 ans=dinic();

92if(!ans)

95 printf("

%d\n

",ans);

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

102}

103return0;

104 }

網路流24題 搭配飛行員 飛行員配對方案

網路流24題 搭配飛行員 輸入檔案 flyer.in 輸出檔案 flyer.out 簡單對比 時間限制 1 s 記憶體限制 128 mb 問題描述 飛行大隊有若干個來自各地的駕駛員,專門駕駛一種型號的飛機,這種飛機每架有兩個駕駛員,需乙個正駕駛員和乙個副駕駛員。由於種種原因,例如相互配合的問題,有些...

網路流24題 飛行員配對方案問題

原題目有special judge所以我將題目去掉special judge之後如下 問題描述 第二次世界大戰時期,英國皇家空軍從淪陷國徵募了大量外籍飛行員。由皇家空軍派出 的每一架飛機都需要配備在航行技能和語言上能互相配合的 2 名飛行員,其中 1 名是英國飛 行員,另 1 名是外籍飛行員。在眾多...

網路流24題 飛行員配對方案問題

luogu 2756 給出n個英國飛行員和m個外籍飛行員,給出每個英國飛行員能配合的外籍飛行員編號,求最多可以選出多少對能互相配合的飛行員 最經典的二分圖匹配問題。其實用匈牙利演算法更合適,在時間複雜度上會更加優秀。用網路流來做的話,超級源點向每個英國飛行員連流量為1的邊,每個英國飛行員向能配合的外...