大学班级选班长,N 个同学均可以发表意见
若意见为 A B 则表示 A 认为 B 合适,意见具有传递性,即 A 认为 B 合适,B 认为 C 合适,则 A 也认为 C 合适
勤劳的 TT 收集了M条意见,想要知道最高票数,并给出一份候选人名单,即所有得票最多的同学,你能帮帮他吗?
Input
本题有多组数据。第一行 T 表示数据组数。每组数据开始有两个整数 N 和 M (2 <= n <= 5000, 0 <m <= 30000),接下来有 M 行包含两个整数 A 和 B(A != B) 表示 A 认为 B 合适。

Output对于每组数据,第一行输出 “Case x: ”,x 表示数据的编号,从1开始,紧跟着是最高的票数。
接下来一行输出得票最多的同学的编号,用空格隔开,不忽略行末空格!

Sample Input
2
4 3
3 2
2 0
2 1
3 3
1 0
2 1
0 2
Sample Output
Case 1: 2
0 1
Case 2: 2
0 1 2

思路
有向图一般的思路就是先用Kahn算法求出强连通分量SCC,然后缩点,也就是将互相可到达和单向可到达分开。
缩点后,不难发现对于属于第i个SCC的点来说,答案分为
两部分,令SCC[i]表示第i个SCC中点的个数
当前SCC中的点,ans+=SCC[i]-1(去除自己)
其它SCC中的点
SUM(SCC[j]),其中j可到达I
稍加思考,可以发现最后答案一定出现在出度为0的SCC
中,
可以用反证法证明
因此我们将边反向,对每个入度为0的点进行dfs,计算其
能到达的点的SUM(SCC[j]),即可得到答案。
Kosaraju算法的步骤:
算法步骤
第一-遍dfs确定原图的逆后序序列
第二遍dfs在反图中按照逆后序序列进行遍历
反图即将原图中的有向边反向
每次由起点遍历到的点即构成一个SCC
(现在做题越来越吃力了,感觉自己好菜,刚开始的算法还能一边理解一边证明一边记忆,现在算法就是直接按照步骤和ppt上代码来,证明什么的根本不敢想)

代码

#include<bits/stdc++.h>
#define mn 5010
#define mm 30010
using namespace std;
int N,M;
int tot1=0,tot2=0,tot3=0,dcnt,scnt,ans,num=1;
int head1[mn],head2[mn],head3[mn],in_deg[mn],dfn[mn],scc[mn],aans[mn],vis1[mn],vis2[mn],vis3[mn],mscc[mn];
struct edge{int v,next;
};
void init(){tot1=0,tot2=0,tot3=0;dcnt=0,scnt=0,ans=0;for(int i=0;i<mn;i++){head1[i]=-1;head2[i]=-1;head3[i]=-1;vis1[i]=0;vis2[i]=0;vis3[i]=0;in_deg[i]=0;dfn[i]=0;scc[i]=0;aans[i]=0;mscc[i]=0;}
}
edge e1[mm],e2[mm],e3[mm];
void add1(int u,int v){e1[++tot1].v=v;e1[tot1].next=head1[u];head1[u]=tot1;
}
void add2(int u,int v){e2[++tot2].v=v;e2[tot2].next=head2[u];head2[u]=tot2;
}
void add3(int u,int v){e3[++tot3].v=v;e3[tot3].next=head3[u];head3[u]=tot3;in_deg[v]++;
}
void dfs1(int u){vis1[u]=1;for(int i=head1[u];i!=-1;i=e1[i].next){int v=e1[i].v;if(!vis1[v])dfs1(v);}dfn[++dcnt]=u;//dfs后序
}
void dfs2(int u){vis2[u]=scnt;scc[scnt]++;for(int i=head2[u];i!=-1;i=e2[i].next){int v=e2[i].v;if(!vis2[v])dfs2(v);}
}
void dfs3(int u){ans+=scc[u];vis3[u]=1;for(int i=head3[u];i!=-1;i=e3[i].next){int v=e3[i].v;if(!vis3[v])dfs3(v);}
}
void kosaraju(){dcnt=0,scnt=0;for(int i=1;i<=N;i++)if(!vis1[i])dfs1(i);for(int i=N;i>=1;i--)if(!vis2[dfn[i]]){++scnt;dfs2(dfn[i]);}
}
int main(){cin.sync_with_stdio(false);int T;cin>>T;for(int i=0;i<T;i++){cin>>N>>M;init();for(int i=1;i<=M;i++){int A,B;cin>>A>>B;A++;B++;add1(A,B);add2(B,A);}kosaraju();//缩点 for(int i=1;i<=N;i++)for(int j=head2[i];j!=-1;j=e2[j].next){int v=e2[j].v;if(vis2[i]==vis2[v])continue;add3(vis2[i],vis2[v]);}for(int i=1;i<=scnt;i++)if(in_deg[i]==0){ans=0;memset(vis3,0,sizeof(vis3));dfs3(i);ans--;aans[i]+=ans;}int mans=0;for(int i=1;i<=scnt;i++)mans=max(mans,aans[i]);for(int i=1;i<=scnt;i++)if(aans[i]==mans)mscc[i]=1;cout<<"Case "<<num<<": "<<mans<<endl;int sum=0;for(int i=1;i<=N;i++)if(mscc[vis2[i]]){if(sum==0){cout<<i-1;sum++;}elsecout<<" "<<i-1;}cout<<endl;num++;}return 0;
}

WEEK8-C-班长竞选相关推荐

  1. 扁平活力学生工作班长竞选PPT模板

    模板介绍 精美PPT模板设计,扁平活力学生工作班长竞选PPT模板.一套学生会竞选幻灯片模板,内含灰色多种配色,精美风格设计,动态播放效果,精美实用. 一份设计精美的PPT模板,可以让你在汇报演讲时脱颖 ...

  2. Week8 作业 C - 班长竞选 SCC Kosaraju HDU - 3639

    题目描述 大学班级选班长,N 个同学均可以发表意见 若意见为 A B 则表示 A 认为 B 合适,意见具有传递性,即 A 认为 B 合适,B 认为 C 合适,则 A 也认为 C 合适 勤劳的 TT 收 ...

  3. 程序设计思维与实践 Week8 作业 C - 班长竞选

    题目描述 大学班级选班长,N 个同学均可以发表意见 若意见为 A B 则表示 A 认为 B 合适,意见具有传递性,即 A 认为 B 合适,B 认为 C 合适,则 A 也认为 C 合适 勤劳的 TT 收 ...

  4. 【Week8作业 C】班长竞选【SCC缩点】

    题意: 大学班级选班长,n个同学均可以发表意见.若意见为A B,则表示A认为B合适.意见具有传递性,即A认为B合适,B认为C合适,则A也认为C合适.共m条意见,要求出最高票数和候选人名单. 思路: 有 ...

  5. java班长竞选投票_竞选班长采取投票式,引家长不满,班主任:您说该怎么选?...

    竞选班长采取投票式,引家长不满,班主任:您说该怎么选? 重庆市某小学二(7)班,上周班队会上进行了班长的选举,学生通过投票的方式来选出正.副两名班长. 二(2)班共有60名学生,其中蒋文浩同学得票数最 ...

  6. 程序设计思维 C - 班长竞选 (强连通分量、kosaraju算法)

    题目 大学班级选班长,N 个同学均可以发表意见 若意见为 A B 则表示 A 认为 B 合适,意见具有传递性,即 A 认为 B 合适,B 认为 C 合适,则 A 也认为 C 合适 勤劳的 TT 收集了 ...

  7. 【C - 班长竞选】

    题意: 大学班级选班长,N 个同学均可以发表意见 若意见为 A B 则表示 A 认为 B 合适,意见具有传递性,即 A 认为 B 合适,B 认为 C 合适,则 A 也认为 C 合适 勤劳的 TT 收集 ...

  8. Week8 :差分约束,拓扑排序和kahn,强连通图和kosaraju

    文章目录 差分约束 题目-区间选点II 输入输出 解题 代码 拓扑序列-kahn 题目-猫猫向前冲 输入输出 解题 代码 强连通图SCC-kosaraju 题目-班长竞选 输入输出 解题 代码 差分约 ...

  9. 程序设计——第八周(差分约束:选数问题;拓扑排序:求比赛名次;scc:选班长)

    A.差分选数 题目描述 给定一个数轴上的 n 个区间,要求在数轴上选取最少的点使得第 i 个区间 [ai, bi] 里至少有 ci 个点 使用差分约束系统的解法解决这道题 使用差分约束系统的解法解决这 ...

  10. 直接在Visual Studio代码编辑器中加密字符串文件

    String encryption is used everywhere in desktop & mobile software. You might not even know about ...

最新文章

  1. 开通会员配送费反而更高了?美团外卖发致歉声明!
  2. 朋友圈里的一张组合逻辑图
  3. python中处理日期和时间的标准模块是-Python time模块参考手册
  4. listen函数的第二个参数_JavaScript数组构造from函数
  5. .Net Core迁移到MSBuild的多平台编译问题
  6. 前端学习(759):预解析案例
  7. List中对象model的排序问题
  8. 《学习之道》第十章方法空间能力是可以后天形成的
  9. HTTPS的SSL证书配置
  10. Java实验报告(基础练习、选择循环、数组、字符串及类和对象)
  11. 乾颐堂现任明教教主(2014年课程)TCPIP协议详解卷一 第四节课笔记
  12. 关于U盘格式化以后容量突然减少很多的解决办法
  13. 实习测试的一个月总结与心得
  14. conan入门(二十六):使用make编译erpc/erpcgen(makefile)
  15. 用PS制作燃烧的火焰人物
  16. 如何利用Photoshop进行快速切图
  17. get 传值 是params
  18. 服务器系统如何重装?
  19. 接口请求报错 504 Gateway Time-out
  20. tomcat 日志禁用

热门文章

  1. linux系统运维核心笔试题-2020年9月1日最新
  2. 中高级日语语法笔记03——并列助词
  3. 剪映电脑版如何设置局部动态马赛克
  4. 通达信接口最新版wind量化特征
  5. 字符串排序java_开发人员是如何使用Java进行排序?
  6. css 文字超出部分自动加省略号
  7. 《网络是如何连接的》笔记——4 通过接入网进入互联网内部
  8. 制作一个简单HTML电影网页设计(HTML+CSS)---电影主题网站 6页带
  9. DevOps的这些经典著作,你都看过了吗?
  10. 中科院陈玉福算法设计与分析 动态规划矩阵连乘计算问题