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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

POJ-2186 Popular Cows (Tarjan缩点) 文末有测试数据

發布時間:2024/4/18 编程问答 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 POJ-2186 Popular Cows (Tarjan缩点) 文末有测试数据 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目鏈接
NNN個牛,MMM個關系 (A,B)A(A,B)A(AB)A認為BBB是受歡迎的。求受所有牛歡迎的牛的數量。

思路

同一個強聯通分量里面的牛是相互受歡迎的,我們將所有的聯通分量求出來之后,那些出度為零的聯通分量就是答案,前提保證這樣的聯通分量只有一個。

#include <map> #include <set> #include <cmath> #include <queue> #include <vector> #include <stdio.h> #include <iostream> #include <numeric> #include <algorithm> #include <cstring> #include <time.h> #define LL long long #define P pair<int, int> #define lowbit(x) (x & -x) #define mem(a, b) memset(a, b, sizeof(a)) #define mid ((l + r) >> 1) #define lc rt<<1 #define rc rt<<1|1 #define endl '\n' const int maxn = 1e4 + 5; const int inf = 0x3f3f3f3f; const int mod = 1e9 + 7; using namespace std; vector<int> g[maxn]; int Stack[maxn], low[maxn], dfn[maxn], inStack[maxn], belong[maxn]; int vis[maxn], color[maxn]; int now, len, cnt; void init() {now = len = cnt = 0;mem(inStack, 0);mem(belong, 0);mem(dfn, 0);mem(low, 0); } void tarjan(int x) {low[x] = dfn[x] = ++now;Stack[++len] = x;inStack[x] = 1;int tmp = g[x].size();for (int i = 0; i < tmp; ++i) {int y = g[x][i];if (!dfn[y]) tarjan(y), low[x] = min(low[x], low[y]);else if (inStack[y]) low[x] = min(low[x], low[y]);}if (dfn[x] == low[x]) {++cnt;int top;while (Stack[len] != x) {top = Stack[len--];belong[top] = cnt;inStack[top] = 0;}top = Stack[len--];belong[top] = cnt;inStack[top] = 0;} } int main() {ios::sync_with_stdio(false);cin.tie(0); cout.tie(0);int n, m;while (cin >> n >> m) {for (int i = 1; i <= n; ++i) {g[i].clear();}for (int i = 0, u,v; i < m; ++i) {cin >> u >> v;g[u].push_back(v);}init();for (int i = 1; i <= n; ++i) {if (dfn[i]) continue;tarjan(i);}mem(vis, 0);for (int i = 1; i <= n; ++i) {for (int j = 0; j < (int)g[i].size(); ++j) {int v = g[i][j];int l = belong[i];int r = belong[v];if (l == r) continue;vis[l] = 1;}}int sum = 0, ans = 0, flag;for (int i = 1; i <= n; ++i) {if (vis[belong[i]] == 0) {vis[belong[i]] = 1;sum++;flag = belong[i];}}for (int i = 1; i <= n; ++i) {if (belong[i] == flag) ans++;}if (sum != 1) ans = 0;cout << ans << endl;}return 0; }/* 3 3 1 2 2 3 3 13 3 1 2 2 1 2 35 4 1 4 2 4 3 4 5 45 5 1 2 2 3 3 1 1 4 4 55 6 1 2 2 3 3 1 1 4 4 5 5 32 2 1 2 2 13 2 1 2 2 16 6 1 2 2 3 3 1 1 4 4 5 5 35 6 1 2 2 3 3 1 1 4 4 5 5 45 7 4 1 1 2 2 3 3 1 1 4 4 5 5 45 6 1 2 2 3 3 1 1 4 4 5 5 17 9 1 2 2 3 3 1 4 5 5 6 6 4 4 7 7 1 1 76 6 1 2 2 3 3 1 4 5 5 6 6 44 4 1 2 2 3 3 1 1 44 4 1 2 2 3 3 1 4 15 6 1 2 2 3 3 1 5 1 5 4 3 47 9 1 2 2 3 3 1 5 1 5 4 3 4 4 7 7 6 6 43 1 1 1 5 2 0 0 2 5 5 4 0 1 3 1 3 */

總結

以上是生活随笔為你收集整理的POJ-2186 Popular Cows (Tarjan缩点) 文末有测试数据的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 久久美女精品 | 啪啪免费视频网站 | 粉嫩av一区二区三区 | 无码成人精品区在线观看 | 国产孕妇孕交大片孕 | avtt在线播放 | 看免费毛片 | 国产亚洲第一页 | 久久久精品999 | 日韩黄色片网站 | 国产精品二区一区二区aⅴ 一卡二卡三卡在线观看 | 欧美一区精品 | 国产一区影院 | 五月激情婷婷在线 | 国产伦精品一区二区三区视频网站 | av天天操| av999| av色播 | 九九热在线观看视频 | 成年人久久 | 韩国黄色一级片 | 99久久精品国产成人一区二区 | 爱爱视频免费看 | av一级 | 欧美aa一级| 疯狂撞击丝袜人妻 | 国产视频一二三 | 国产高清中文字幕 | 欧美日韩视频免费 | 日韩va中文 | 欧美区一区 | 国产精品一区二区免费视频 | 精品91视频 | 18在线观看免费入口 | 一级少妇精品久久久久久久 | 少妇中出视频 | 天堂av免费在线观看 | 真实的国产乱xxxx在线 | 大片视频免费观看视频 | 樱花影院电视剧免费 | 久久超碰av| 男人的天堂99 | 一级不卡| 天堂中文字幕av | 香蕉视频国产在线观看 | 久操精品视频 | 国产传媒av在线 | 国产拍拍拍拍拍拍拍拍拍拍拍拍拍 | 日本一区二区三区视频在线 | 成年人在线视频网站 | 国产真实乱在线更新 | 国产乱人视频 | 日韩一级片中文字幕 | 国产91九色 | 国产欧美日韩在线视频 | 国产又大又粗又爽的毛片 | 成人免费无码大片a毛片抽搐色欲 | 一级黄色片在线播放 | 欧洲精品一区 | 一本久 | 人妻夜夜爽天天爽 | 欧美三级午夜理伦三级老人 | 大尺度做爰啪啪床戏 | 亚洲日本黄色 | 亚洲精品视频91 | 日本久操 | 香蕉视频在线观看免费 | 粉嫩一区二区三区 | av片国产 | 哈利波特3在线观看免费版英文版 | 国产精品日 | 日本一区二区在线免费 | 欧美偷拍少妇精品一区 | 中文字幕9 | 色丁香综合 | 91成年影院 | 国产18一19sex性护士 | 精品夜夜澡人妻无码av | 色人阁在线视频 | 一级片一级| 久久亚洲一区二区三区四区 | 我和岳m愉情xxxⅹ视频 | 欧美日韩高清在线 | 人人做人人爱人人爽 | 久久精品视频免费播放 | 国语对白精彩对话 | 色爱亚洲 | 精品无码人妻一区二区免费蜜桃 | 男女男精品网站 | 精品国产91久久久久久久妲己 | 欧美三级黄 | 日本高清有码视频 | 欧美午夜小视频 | 国模无码视频一区二区三区 | 一区二区视频在线播放 | 久久潮| 亚洲国产婷婷香蕉久久久久久99 | 超碰66 | 亚洲精品1区2区3区 国产丝袜网站 |