日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【LA3415 训练指南】保守的老师 【二分图最大独立集,最小割】

發布時間:2023/12/18 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【LA3415 训练指南】保守的老师 【二分图最大独立集,最小割】 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題意

? Frank是一個思想有些保守的高中老師。有一次,他需要帶一些學生出去旅行,但又怕其中一些學生在旅行中萌生愛意。為了降低這種事情發生的概率,他決定確保帶出去的任意兩個學生至少要滿足下面四條中的一條。

1.身高相差大于40厘米

2.性別相同

3.最喜歡的音樂屬于不同類型

4.最喜歡的體育比賽相同

你的任務是幫助Frank挑選盡量多的學生,使得任意兩個學生至少滿足上述條件中的一條。

分析

?這個模型叫二分圖的最大獨立集。既選擇盡量多的結點,使得任意兩個結點不相鄰(既任意一條邊的兩個端點不會被同時選中)。最大獨立集與最小覆蓋是互補的,因此答案就是結點總數減去最大匹配數。

?建模:將每個人看作一個結點,如果兩個人四個條件都不滿足,就意味著他們不能同時被選擇,連一條無向邊。這樣,問題就轉換為求這個圖的最大獨立集。因為他們每個人不是男生就是女生,所以這個圖是二分圖。

?按照慣例,我依然是用網絡流來做的最大匹配。原因依然是不會KM···等哪天(8012年)我學會來并且心情好可能會來補一下KM的代碼。

??

1 #include <cstdio> 2 #include <algorithm> 3 #include <cstring> 4 #include <iostream> 5 #include <cmath> 6 #include <queue> 7 8 using namespace std; 9 const int maxn=1000+10; 10 const int maxm=2000000+100; 11 12 const int INF=2147000000; 13 struct Dinic{ 14 int head[maxn],Next[maxm],to[maxm],cap[maxm],flow[maxm]; 15 int sz,n,m,s,t; 16 bool vis[maxn]; 17 int cur[maxn],d[maxn]; 18 void init(int n){ 19 this->n=n; 20 memset(head,-1,sizeof(head)); 21 this->sz=-1; 22 } 23 void add_edge(int a,int b,int c){ 24 ++sz; 25 to[sz]=b; 26 cap[sz]=c;flow[sz]=0; 27 Next[sz]=head[a];head[a]=sz; 28 ++sz; 29 to[sz]=a; 30 cap[sz]=c;flow[sz]=c; 31 Next[sz]=head[b];head[b]=sz; 32 } 33 bool BFS(){ 34 memset(vis,0,sizeof(vis)); 35 queue<int>Q; 36 vis[s]=1; 37 d[s]=0; 38 Q.push(s); 39 while(!Q.empty()){ 40 int u=Q.front();Q.pop(); 41 for(int i=head[u];i!=-1;i=Next[i]){ 42 int v=to[i]; 43 if(!vis[v]&&cap[i]>flow[i]){ 44 vis[v]=1; 45 d[v]=d[u]+1; 46 Q.push(v); 47 } 48 } 49 } 50 return vis[t]; 51 } 52 int DFS(int x,int a){ 53 if(x==t||a==0)return a; 54 int Flow=0,f; 55 for(int& i=cur[x];i!=-1;i=Next[i]){ 56 int v=to[i]; 57 if(d[v]==d[x]+1&&(f=DFS(v,min(a,cap[i]-flow[i])))>0){ 58 Flow+=f; 59 flow[i]+=f; 60 flow[i^1]-=f; 61 a-=f; 62 if(a==0)break; 63 } 64 } 65 return Flow; 66 } 67 int Maxflow(int s,int t){ 68 this->s=s,this->t=t; 69 int Flow=0; 70 while(BFS()){ 71 for(int i=0;i<=n;i++) 72 cur[i]=head[i]; 73 74 Flow+=DFS(s,INF); 75 } 76 return Flow; 77 } 78 }dinic; 79 int T,n; 80 int high[maxn]; 81 char sex[maxn]; 82 string mus[maxn],phy[maxn]; 83 int main(){ 84 scanf("%d",&T); 85 for(int t=1;t<=T;t++){ 86 scanf("%d",&n); 87 for(int i=1;i<=n;i++){ 88 scanf("%d %c",&high[i],&sex[i]); 89 cin>>mus[i]>>phy[i]; 90 } 91 dinic.init(n+2); 92 for(int i=1;i<=n;i++){ 93 if(sex[i]=='M'){ 94 for(int j=1;j<=n;j++){ 95 if(sex[j]=='F'&&abs(high[i]-high[j])<=40&&mus[i]==mus[j]&&phy[i]!=phy[j]){ 96 dinic.add_edge(i,j,1); 97 } 98 } 99 } 100 } 101 for(int i=1;i<=n;i++){ 102 if(sex[i]=='M') 103 dinic.add_edge(0,i,1); 104 } 105 for(int i=1;i<=n;i++){ 106 if(sex[i]=='F') 107 dinic.add_edge(i,n+1,1); 108 } 109 int ans=dinic.Maxflow(0,n+1); 110 printf("%d\n",n-ans); 111 } 112 return 0; 113 } View Code

?

?? 其實我覺得這道題不知道這個模型只是考慮最小割的話也能想。去除最少的學生使得剩下的所有學生之間任意兩個之間都滿足四個條件中的一條。我們在學生之間連的邊是這兩個學生間只能選一個或者都不選,那個割掉這條邊就代表去掉這兩個學生中的一個。所以可以求出最小割來以后,用總的人數n減掉最小割。

? 哇萬能的最小割我感覺這樣想比背什么模型好多了啊!

?

轉載于:https://www.cnblogs.com/LQLlulu/p/9307386.html

總結

以上是生活随笔為你收集整理的【LA3415 训练指南】保守的老师 【二分图最大独立集,最小割】的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 日韩网站视频 | 扒开伸进免费视频 | 欧美色射| 日本福利视频一区 | 99免费国产 | 成人免费视频网 | 伊人宗合 | 污片在线免费观看 | 精品一区二区三区精华液 | 国产一区精品在线 | 97精品久久久 | 内射后入在线观看一区 | 日本久久网站 | 日韩欧美在线观看一区 | 国产精品亚洲一区二区三区 | 免费a v网站 | 欧美亚色 | 国产欧美精品一区二区色综合朱莉 | 亚洲第一免费播放区 | 日本色综合网 | 黄色av免费 | 亚洲福利视频一区二区 | 成年人免费毛片 | 精品人妻一区二区免费 | 欧美巨乳在线观看 | 91久久精品视频 | 精东av在线 | 国产精品亚洲一区二区三区在线观看 | 国产又爽又黄的激情精品视频 | 在线观看黄色大片 | 黑人一区 | 污站在线观看 | 九九九热 | 亚洲精品在线电影 | 亚洲黄色网址 | 色香色香欲天天天影视综合网 | 视频国产一区 | 桃色成人| ww久久| 91久久综合| 亚洲伊人久久综合 | 久久久久久免费视频 | 午夜福利啪啪片 | 麻豆视频观看 | 肉丝美脚视频一区二区 | 国产乱妇4p交换乱免费视频 | 美女网站黄频 | 天天射天天干 | 国产一级aa大片毛片 | 成年女人毛片 | 偷偷久久 | 亚洲精品大全 | 日本特黄视频 | free性满足hd国产精品久 | 在线观看亚洲精品视频 | 成人听书哪个软件好 | 黄色在线免费视频 | 久久国精品 | 亚洲国产精品狼友在线观看 | 永久免费看成人av的动态图 | 国产精品欧美大片 | 最新视频在线观看 | 成人性做爰aaa片免费看不忠 | 亚洲网站在线播放 | 午夜色播 | 动漫同人高h啪啪爽文 | 夫妻性生活自拍 | 日韩av中文字幕在线播放 | 亚洲男人在线 | 爱爱爱爱网站 | 精品黑人一区二区三区在线观看 | 国产亚洲精久久久久久无码苍井空 | 亚洲午夜久久久久久久久红桃 | 亚洲黄色中文字幕 | 欧美午夜性 | 久久久久人妻一区二区三区 | 神马久久久久久久久久 | 国产成人欧美 | 国产精品久久久久久久久久久不卡 | 午夜精品极品粉嫩国产尤物 | 8x8x国产精品一区二区 | 精品欧美一区二区久久久久 | 激情伦成人综合小说 | 欧美高清精品一区二区 | 少妇人妻无码专区视频 | 操穴网站| 久久久久久久久久久久久女国产乱 | 亚洲熟妇无码av | 欧美在线一级视频 | 被各种性器调教到哭vk | 毛片久久久 | 亚洲乱码国产一区三区 | 美女扒开内看个够网站 | 午夜视频1000| 韩国成人免费视频 | 日韩激情在线视频 | 黄色aaaaa| 色哟哟在线视频 | av在线免费播放网址 |