【题目链接】

http://www.lydsy.com/JudgeOnline/problem.php?id=2438

【题意】

N个人中有一个杀手,每次询问一个人可能被杀或被告知其认识的人中谁是杀手谁是平民,问不被杀的情况下知道谁是杀手的概率。

【思路】

对于一个scc,如果我们询问一个不是杀手的人,就可以成功遍历整个scc。

求scc,然后缩点。

对于每一个入度为0的scc,我们需要去询问一下,那么被杀的概率为1/n * ans。ans为入度为0的scc个数。

但还有一种特殊的情况,如果一个scc入度为0,但它的所有出度的入度皆大于1,那么它的出度可以不通过询问这个scc得知,而且最终通过其他n-1个点推出这个点的情况。这时候需要对ans-1,但这种情况只计算一次。

【代码】

  1. #include<set>
  2. #include<cmath>
  3. #include<queue>
  4. #include<vector>
  5. #include<cstdio>
  6. #include<cstring>
  7. #include<iostream>
  8. #include<algorithm>
  9. #define trav(u,i) for(int i=front[u];i;i=e[i].nxt)
  10. #define FOR(a,b,c) for(int a=(b);a<=(c);a++)
  11. using namespace std;
  12.  
  13. typedef long long ll;
  14. const int N = 2e5+;
  15. const int M = 7e5+;
  16.  
  17. ll read() {
  18. char c=getchar();
  19. ll f=,x=;
  20. while(!isdigit(c)) {
  21. if(c=='-') f=-; c=getchar();
  22. }
  23. while(isdigit(c))
  24. x=x*+c-'',c=getchar();
  25. return x*f;
  26. }
  27.  
  28. struct Edge {
  29. int v,nxt;
  30. }e[M];
  31. int en=,front[N];
  32. void adde(int u,int v)
  33. {
  34. e[++en]=(Edge){v,front[u]}; front[u]=en;
  35. }
  36.  
  37. int pre[N],lowlink[N],scc_cnt,sccno[N],S[N],top,dfn;
  38.  
  39. void tarjan(int u)
  40. {
  41. pre[u]=lowlink[u]=++dfn;
  42. S[++top]=u;
  43. trav(u,i) {
  44. int v=e[i].v;
  45. if(!pre[v]) {
  46. tarjan(v);
  47. lowlink[u]=min(lowlink[v],lowlink[u]);
  48. } else
  49. if(!sccno[v])
  50. lowlink[u]=min(lowlink[u],pre[v]);
  51. }
  52. if(pre[u]==lowlink[u]) {
  53. ++scc_cnt;
  54. for(;;) {
  55. int x=S[top--];
  56. sccno[x]=scc_cnt;
  57. if(x==u) break;
  58. }
  59. }
  60. }
  61.  
  62. int cnt[N],in[N],n,m,ans;
  63.  
  64. int main()
  65. {
  66. n=read(),m=read();
  67. int u,v;
  68. FOR(i,,m) {
  69. u=read(),v=read();
  70. adde(u,v);
  71. }
  72. FOR(i,,n) if(!pre[i]) tarjan(i);
  73. FOR(u,,n) {
  74. cnt[sccno[u]]++;
  75. trav(u,i) {
  76. int v=e[i].v;
  77. if(sccno[u]!=sccno[v])
  78. in[sccno[v]]++;
  79. }
  80. }
  81. FOR(i,,scc_cnt) if(!in[i]) ans++;
  82. int flag=;
  83. FOR(i,,n)
  84. if(cnt[sccno[i]]==&&in[sccno[i]]==) {
  85. int f=;
  86. trav(i,j) {
  87. int v=e[j].v;
  88. if(in[sccno[v]]<=) { f=; break; }
  89. }
  90. if(f) {
  91. flag=; break;
  92. }
  93. }
  94. ans-=flag;
  95. printf("%.6lf\n",(double)(n-ans)/n);
  96. return ;
  97. }

bzoj 2438 [中山市选2011]杀人游戏(SCC+概率)的更多相关文章

  1. BZOJ——2438: [中山市选2011]杀人游戏

    http://www.lydsy.com/JudgeOnline/problem.php?id=2438 Description 一位冷血的杀手潜入 Na-wiat,并假装成平民.警察希望能在 N 个 ...

  2. bzoj 2438: [中山市选2011]杀人游戏【tarjan】

    没看太懂题意orz 最优的是tarjan缩点之后问入度为0的点,因为问这个点可以知道整个块的情况 答案是这ans个入度为0的点都不是杀手的概率\( \frac{n-ans}{n} \) 但是有特殊情况 ...

  3. BZOJ 2438: [中山市选2011]杀人游戏

    Description 给你一个有向图,求至少询问多少次能够得到全部点的信息. Sol Tarjan + 强连通分量缩点 + 判断. 先缩点,如果我们知道了强连通分量里的任意一个点,我们就可以知道这些 ...

  4. [bzoj 2438][中山市选2011]杀人游戏 概率+tarjan

    考试的时候想了很多,不知道它那个概率究竟是怎么算..没想到能蒙30分.rp爆发hhh 题解转自不知道哪里来的老师发的(代码出自自己). 实际上警察就是两种结果——查到犯人或死亡,而死亡事件一定是包含在 ...

  5. [BZOJ 2438] [中山市选2011]杀人游戏 Tarjan缩点

    这个题很容易想到正解就是缩点找入度为零的点,那么我们考虑一种特殊情况就是,一个入度为零的点我们不访问他就知道他是不是凶手,那么这样的话就是:I. 他是一个真·孤立的点 II. 他在图里但是在他的强联通 ...

  6. BZOJ 2438 [中山市选2011]杀人游戏 ——期望DP

    发现每一次死亡的几率相等,所以只需要判断最少问多少人即可. 并且环上的点任意询问都可以. 所以直接Tarjan缩点,然后计算入度为0的点的数目. 但是还有一些情况的时候会减少一次询问,比如说:$1-& ...

  7. bzoj2438: [中山市选2011]杀人游戏(强联通+特判)

    2438: [中山市选2011]杀人游戏 题目:传送门 简要题意: 给出n个点,m条有向边,进行最少的访问并且可以便利(n-1)个点,求这个方案成功的概率 题解: 一道非常好的题目! 题目要知道最大的 ...

  8. BZOJ_2438_[中山市选2011]杀人游戏 _强连通分量

    BZOJ_2438_[中山市选2011]杀人游戏 _强连通分量 Description 一位冷血的杀手潜入 Na-wiat,并假装成平民.警察希望能在 N 个人里面,查出谁是杀手.警察能够对每一个人 ...

  9. bzoj2438[中山市选2011]杀人游戏

    Description 一位冷血的杀手潜入 Na-wiat,并假装成平民.警察希望能在 N 个人里面, 查出谁是杀手. 警察能够对每一个人进行查证,假如查证的对象是平民,他会告诉警察,他 认识的人, ...

随机推荐

  1. Hibernate逍遥游记-第13章 映射实体关联关系-004双向多对多(inverse="true")

    1. <?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hi ...

  2. Android:创建Android工程

    创建Android工程,在Eclipse左栏右键 new->project..   (版本不一样,名字会有所区别) 然后选择Android下的Android application projec ...

  3. Dictionary<Key,Value>的用法

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  4. C++:对象指针

    对象指针概念:每一个对象在初始化后都会在内存中占有一定的空间.因此,既可以通过对象名访问, 也可以通过一个对象地址来访问一个对象.对象指针就是用于存放对象地址的变量. 声明对象指针的一般语法格式为:类 ...

  5. javascript正则表达式控制input只能输入数字

    不能输入中文 <input type="text" name="textfield"  onkeyup="this.value=this.val ...

  6. 关于PHP 7你必须知道的五件事

    1.今年的计划表已出.PHP 7时间表RFC投票一直通过, PHP 7将在2015年10月发布.尽管有些延迟,但我们还是很高兴它在今年内发布.PHP 7详细时间表由此查看. 2.PHP 要上太空飞船了 ...

  7. weblogic11g 安装集群 —— win2003 系统、单台主机

    weblogic11g 安装集群 —— win2003 系统.单台主机 注意:此为weblogic11g  在win2003系统下(一台主机)的安装集群,linux.hpux.aix及多个主机下原理一 ...

  8. Hibernate HQL查询的参数绑定

    参数绑定: Hibernate中对动态查询参数绑定提供了丰富的支持,那么什么是查询参数动态绑定呢?其实如果我们熟悉传统JDBC编程的话,我们就不难理解查询参数动态绑定,如下代码传统JDBC的参数绑定: ...

  9. BZOJ 2440 完全平方数(莫比乌斯-容斥原理)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2440 题意:给定K.求不是完全平方数(这里1不算完全平方数)的倍数的数字组成的数字集合S ...

  10. 基于Jquery+Ajax+Json+高效分页

    摘要 分页我相信大家存储过程分页已经很熟悉了,ajax更是耳熟能详了,更别说我们的json,等等. 如果说您没用过这些东东的话,我相信看完这篇博文会对您有帮助的,,如果有任何问题不懂或者有bug没问题 ...