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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Light OJ 1373 Strongly Connected Chemicals 二分匹配最大独立集

發布時間:2025/3/21 编程问答 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Light OJ 1373 Strongly Connected Chemicals 二分匹配最大独立集 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

m種陽離子 n種陰離子 然后一個m*n的矩陣 第i行第j列為1代表第i種陰離子和第j種陰離子相互吸引 0表示排斥

求在陽離子和陰離子都至少有一種的情況下 最多存在多少種離子能夠共存

陰陽離子都至少須要存在一種 那么能夠枚舉哪2種離子共存 如果枚舉a b 然后找到全部的和a能夠共存的陰離子(設為x集合)以及和b共存的陽離子(設為y集合)?

如今僅僅需求x集合中和y集合中最多有多少個離子能夠共存 這個求最大獨立集即可了 枚舉全部的a b 取最大值

#include <cstdio> #include <cstring> #include <algorithm> #include <vector> using namespace std; const int maxn = 55; int vis[maxn]; int y[maxn]; vector <int> G[maxn]; int n, m;char a[maxn][maxn]; bool dfs(int u) {for(int i = 0; i < G[u].size(); i++){int v = G[u][i];if(vis[v])continue;vis[v] = true;if(y[v] == -1 || dfs(y[v])){y[v] = u;return true;}}return false; } int match() {int ans = 0;memset(y, -1, sizeof(y));for(int i = 0; i < n; i++){memset(vis, 0, sizeof(vis));if(dfs(i))ans++;}return ans; } int main() {int T;int cas = 1;scanf("%d", &T);while(T--){scanf("%d %d", &n, &m);for(int i = 0; i < n; i++)scanf("%s", a[i]);int ans = 0;for(int i = 0; i < n; i++)for(int j = 0; j < m; j++)if(a[i][j] == '1'){int sum1 = 0, sum2 = 0;for(int h = 0; h < m; h++)if(a[i][h] == '1')sum1++;for(int h = 0; h < n; h++)if(a[h][j] == '1')sum2++;if(ans >= sum1+sum2)continue;for(int h = 0; h < n; h++){G[h].clear();if(a[h][j] == '1'){for(int k = 0; k < m; k++)if(a[i][k] == '1' && a[h][k] == '0')G[h].push_back(k);}}int res = match();if(sum1+sum2-res > ans)ans = sum1+sum2-res;}printf("Case %d: %d\n", cas++, ans);}return 0; }


轉載于:https://www.cnblogs.com/liguangsunls/p/7008156.html

總結

以上是生活随笔為你收集整理的Light OJ 1373 Strongly Connected Chemicals 二分匹配最大独立集的全部內容,希望文章能夠幫你解決所遇到的問題。

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