http://acm.hdu.edu.cn/showproblem.php?pid=1704

遇到标记过的就dfs,把隐含的标记,最后计数需要注意。

  1. #include <cstdio>
  2. #include <cstring>
  3. int n;
  4. int vis[][];
  5. void dfs(int x,int y)
  6. {
  7. for(int i=;i<=n;i++)
  8. if(vis[y][i])
  9. {
  10. vis[x][i]=;
  11. dfs(x,i);
  12. }
  13. }
  14. int main()
  15. {
  16. // freopen("a.txt","r",stdin);
  17. int t,m,a,b;
  18. scanf("%d",&t);
  19. while(t--)
  20. {
  21. memset(vis,,sizeof(vis));
  22. scanf("%d%d",&n,&m);
  23. for(int i=;i<m;i++)
  24. {
  25. scanf("%d%d",&a,&b);
  26. vis[a][b]=;
  27. }
  28. for(int i=;i<=n;i++)
  29. for(int j=;j<=n;j++)
  30. if(vis[i][j])
  31. {
  32. dfs(i,j);
  33. }
  34. int ans=;
  35. for(int i=;i<=n;i++)
  36. for(int j=i+;j<=n;j++)
  37. if(!vis[i][j]&&!vis[j][i]) ans++;
  38. printf("%d\n",ans);
  39. }
  40. return ;
  41. }

也可以用有向图传递闭包的方法。实质是一样的。

  1. #include <cstdio>
  2. #include <cstring>
  3. int vis[][];
  4.  
  5. int main()
  6. {
  7. // freopen("a.txt","r",stdin);
  8. int t,n,m,a,b;
  9. scanf("%d",&t);
  10. while(t--)
  11. {
  12. memset(vis,,sizeof(vis));
  13. scanf("%d%d",&n,&m);
  14. for(int i=;i<m;i++)
  15. {
  16. scanf("%d%d",&a,&b);
  17. vis[a][b]=;
  18. }
  19. for(int k=;k<=n;k++)
  20. for(int i=;i<=n;i++)
  21. if(vis[i][k])
  22. {
  23. for(int j=;j<=n;j++)
  24. vis[i][j]=vis[i][j]||vis[k][j];
  25. }
  26. int ans=;
  27. for(int i=;i<=n;i++)
  28. for(int j=i+;j<=n;j++)
  29. if(!vis[i][j]&&!vis[j][i]) ans++;
  30. printf("%d\n",ans);
  31. }
  32. return ;
  33. }

hdu - 1704 Rank(简单dfs)的更多相关文章

  1. HDU 1704 Rank

    Rank Time Limit: 1000ms Memory Limit: 32768KB This problem will be judged on HDU. Original ID: 17046 ...

  2. hdu 1704 Rank (floyd闭包)

    Rank Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  3. HDU 1704 Rank【传递闭包】

    解题思路:给出n个选手,m场比赛,问不能判断胜负的询问最多有多少种 用传递闭包即可 但是如果直接用3重循环会超时 在判断d[i][j]=d[i][k]||d[k][j]是否连通的时候 可以加一个if语 ...

  4. HDOJ(HDU).1035 Robot Motion (DFS)

    HDOJ(HDU).1035 Robot Motion [从零开始DFS(4)] 点我挑战题目 从零开始DFS HDOJ.1342 Lotto [从零开始DFS(0)] - DFS思想与框架/双重DF ...

  5. Counting Cliques HDU - 5952 单向边dfs

    题目:题目链接 思路:这道题vj上Time limit:4000 ms,HDU上Time Limit: 8000/4000 MS (Java/Others),且不考虑oj测评机比现场赛慢很多,但10月 ...

  6. HDU 1401 Solitaire 双向DFS

    HDU 1401 Solitaire 双向DFS 题意 给定一个\(8*8\)的棋盘,棋盘上有4个棋子.每一步操作可以把任意一个棋子移动到它周围四个方向上的空格子上,或者可以跳过它四个方向上的棋子(就 ...

  7. ACM: hdu 1811 Rank of Tetris - 拓扑排序-并查集-离线

    hdu 1811 Rank of Tetris Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & % ...

  8. HDU 2085 核反应堆 --- 简单递推

    HDU 2085 核反应堆 /* HDU 2085 核反应堆 --- 简单递推 */ #include <cstdio> ; long long a[N], b[N]; //a表示高能质点 ...

  9. Red and Black(简单dfs)

    Red and Black Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

随机推荐

  1. Oracle中的日期数据类型

    TimeStamp日期类型 TimeStamp数据类型用于存储日期的年.月.日,以及时间的小时.分和秒,其中秒值精确到小数点后6位,该数据类型 同时包含时区信息.systimestamp函数的功能是返 ...

  2. AJPFX简述java语言现状和发展

    作为一种最流行的网络编程语言之一,java语言在当今信息化社会中发挥了 重要的作用.Java语言具有面向对象.跨平台.安全性.多线程等特点,这使得java成为许多应用系统的理想开发语言.java应用在 ...

  3. CentOS 7 下用 firewall-cmd / iptables 实现 NAT 转发供内网服务器联网

    自从用 HAProxy 对服务器做了负载均衡以后,感觉后端服务器真的没必要再配置并占用公网IP资源. 而且由于托管服务器的公网 IP 资源是固定的,想上 Keepalived 的话,需要挤出来 3 个 ...

  4. DOM简介及节点、属性、查找节点的方法

    DOM(Document Object Modle) 操作文档的编程接口DOM定义了表示和修改文档的方法,不能修改css样式表,在js中使用DOM方法改变元素的css样式,实质上是在元素上添加行间样式 ...

  5. "CSRF token missing or incorrect."的解决方法.

    现象: Forbidden (403)CSRF verification failed. Request aborted.HelpReason given for failure:CSRF token ...

  6. 机器学习-牛顿方法&指数分布族&GLM

    本节内容 牛顿方法 指数分布族 广义线性模型 之前学习了梯度下降方法,关于梯度下降(gradient descent),这里简单的回顾下[参考感知机学习部分提到的梯度下降(gradient desce ...

  7. OpenGl之旅-—如何使用code blocks创建一个opengl项目

    开始学习opengl啦,练习用的编辑器是code blocks. 首先当然是要清楚如何使用code blocks创建一个opengl项目了. 首先必须先引用opengl的库glut,网上百度下载一个完 ...

  8. spring.net应用

    经过一段时间的调试,终于把spring.net中关于aop的方面给做个了一个比较完整的Demo.包含异常日志和性能日志.spring.net和log4net配置. http://files.cnblo ...

  9. 最全的Java面试宝典

    一. 前言部分 从享受生活的角度上来说:“程序员并不是一种最好的职业,我认为两种人可以做程序员,第一,你不做程序员,你就没有什么工作可做,或者说是即使有可以做的工作但是你非常不愿意去做:第二,你非常痴 ...

  10. Windows 8.1设置WIFI共享以及无法启动承载链接解决方案.

    1.设置WIFI共享方法 2.无法启动承载链接解决方案 1.设置WIFI共享方法 Windows8 windows8.1笔记本wifi热点 wifi共享.快速将笔记本或者台式机的网络共享给手机,平板等 ...