题目链接

2019.9.2更新


第二天睡醒想了想发现好像搜一遍就可以过,赛时写的花里胡哨的还错了,太菜了QAQ

 #include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 3e5 + ;
struct node {
int s, e, next;
}edge[maxn];
int head[maxn], len;
void init() {
memset(head, -, sizeof(head));
len = ;
}
void add(int s, int e) {
edge[len].s = s;
edge[len].e = e;
edge[len].next = head[s];
head[s] = len++;
}
double dp[maxn], dp2[maxn];
int vis[maxn],n;
void dfs(int x) {
if (vis[x])
return;
vis[x] = ;
dp[x] = dp2[x] = ;
if (x == n)
return;
int num = ;
for (int i = head[x]; i != -; i = edge[i].next) {
int y = edge[i].e;
dfs(y);
dp[x] += dp[y];
dp2[x] += dp2[y];
num++;
}
dp[x] += num + , dp[x] /= num;
dp2[x] += (num + )*dp[x], dp2[x] /= num;
}
int main() {
int t;
scanf("%d", &t);
while (t--) {
int m, x, y;
init();
scanf("%d%d", &n, &m);
for (int i = ; i <= m; i++)
scanf("%d%d", &x, &y), add(x, y);
memset(vis, , sizeof(vis));
dfs();
printf("%.2f\n", dp2[]);
}
}

原文


绝望ing!!!

搞了3个小时的D,到最后也没过,吃饭的时候突然想到错了,改一改就过了Orz.

遗憾!!错在求了拓扑序,要用a[n]->a[1],结果用成了n->1。要被队友骂死了QAQ

而且样例刚好1-n是拓扑序(


题意是说,在DAG中从1到n,每次有x/(x+1)的概率到相连的点,1/(x+1)的概率原地不动,(x为相连的点的个数)。每次移动需要一天,每次移动会消耗当前天数数值那么多的能量,求到达n点的期望能量消耗。

一开始就蛮有感觉的,DAG上跑期望dp,先跑期望天数,再跑期望能量,设dp[i]为i点到n点的期望天数,则初始dp[n]=0,转移为$dp[i]=\tfrac{1}{x+1}*\sum dp[j]+\tfrac{1}{x+1}*dp[i]+1$ i->j有边。

然后再跑期望能量,dp2[i]为i到n点的期望能量,初始为dp2[n]=0,转移为$dp2[i]=\tfrac{1}{x+1}*\sum dp2[j]+\tfrac{1}{x+1}*dp2[i]+dp[i]$ i->j有边。

代码极度丑陋,望见谅。

 #include <bits/stdc++.h>
using namespace std;
const int maxn = 4e5 + ;
struct node {
int s, e, next;
}edge[maxn], edge2[maxn];
int head[maxn], head2[maxn], len, len2;
void init() {
memset(head, -, sizeof(head));
memset(head2, -, sizeof(head2));
len = len2 = ;
}
void add(int s, int e) {
edge[len].s = s;
edge[len].e = e;
edge[len].next = head[s];
head[s] = len++;
}
void add2(int s, int e) {
edge2[len2].s = s;
edge2[len2].e = e;
edge2[len2].next = head2[s];
head2[s] = len2++;
}
double dp[maxn], dp2[maxn];
int in[maxn], a[maxn], num[maxn];
void solve(int n) {
int lens = ;
queue<int>q;
for (int i = ; i <= n; i++)
if (in[i] == ) q.push(i);
while (!q.empty()) {
int p = q.front(); q.pop();
a[++lens] = p;
for (int i = head[p]; i != -; i = edge[i].next) {
int y = edge[i].e;
in[y]--;
if (in[y] == )
q.push(y);
}
}
}
int main() {
int t;
scanf("%d", &t);
while (t--) {
int n, m, x, y;
scanf("%d%d", &n, &m);
init();
for (int i = ; i <= n; i++)
in[i] = , num[i] = , dp2[i] = dp[i] = ;
for (int i = ; i <= m; i++)
scanf("%d%d", &x, &y), add(x, y), add2(y, x), in[y]++;//正向反向各存一图,正向跑拓扑,反向求期望
solve(n);//求拓扑序
dp[a[n]] = ;
for (int x = n; x >= ; x--) {//期望dp日常倒推
if (a[x] != n) dp[a[x]] += num[a[x]] + , dp[a[x]] /= num[a[x]];//num[i]为与i点相连的点数
num[a[x]] = ;
for (int i = head2[a[x]]; i != -; i = edge2[i].next) {
int y = edge2[i].e;
dp[y] += dp[a[x]];
num[y]++;
}
}
dp2[n] = ;
for (int x = n; x >= ; x--) {
if (a[x] != n) dp2[a[x]] += (num[a[x]] + ) * dp[a[x]], dp2[a[x]] /= num[a[x]];
for (int i = head2[a[x]]; i != -; i = edge2[i].next) {
int y = edge2[i].e;
dp2[y] += dp2[a[x]];
num[y]++;
}
}
printf("%.2lf\n", dp2[]);
}
}

[2019南京网络赛D题]Robots的更多相关文章

  1. ACM-ICPC 2019南昌网络赛I题 Yukino With Subinterval

    ACM-ICPC 2019南昌网络赛I题 Yukino With Subinterval 题目大意:给一个长度为n,值域为[1, n]的序列{a},要求支持m次操作: 单点修改 1 pos val 询 ...

  2. 2019ICPC南京网络赛A题 The beautiful values of the palace(三维偏序)

    2019ICPC南京网络赛A题 The beautiful values of the palace https://nanti.jisuanke.com/t/41298 Here is a squa ...

  3. HDU 4758 Walk Through Squares (2013南京网络赛1011题,AC自动机+DP)

    Walk Through Squares Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Oth ...

  4. HDU 4751 Divide Groups (2013南京网络赛1004题,判断二分图)

    Divide Groups Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tot ...

  5. HDU 4750 Count The Pairs (2013南京网络赛1003题,并查集)

    Count The Pairs Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others ...

  6. ACM-ICPC 2019南昌网络赛F题 Megumi With String

    ACM-ICPC 南昌网络赛F题 Megumi With String 题目描述 给一个长度为\(l\)的字符串\(S\),和关于\(x\)的\(k\)次多项式\(G[x]\).当一个字符串\(str ...

  7. 2019 南京网络赛A

    南京网络赛自闭现场 https://nanti.jisuanke.com/t/41298 二维偏序经典题型 二维前缀和!!! #include<bits/stdc++.h> using n ...

  8. Robots 2019南京网络赛 (概率dp)

    Robots \[ Time Limit: 1000 ms \quad Memory Limit: 262144 kB \] 题意 有一个机器人要从 \(1\) 点走到 \(n\) 点,每走一步都需要 ...

  9. 2019年南京网络赛E题K Sum(莫比乌斯反演+杜教筛+欧拉降幂)

    目录 题目链接 思路 代码 题目链接 传送门 思路 首先我们将原式化简: \[ \begin{aligned} &\sum\limits_{l_1=1}^{n}\sum\limits_{l_2 ...

随机推荐

  1. Arduino-位操作

    读取指定位的数据 int x=bitRead(0x81,7);    //0x81从右向左依次为第0位到第15位,第2个参数为第7位的1复制给x,使x=1 把数据写到指定位 int x=13; //x ...

  2. 一个错误导致懂了mac系统的PATH环境变量

    一个完全不懂mac系统的强迫症小白,由于搭建环境都按照百度走,所以在执行命令echo $PATH查看PATH内容时发现怎么有这样一串东西 /usr/local/bin:/usr/bin:/bin:/u ...

  3. hihocode 1584 : Bounce (找规律)(2017 北京网络赛G)

    题目链接 比赛时随便找了个规律,然后队友过了.不过那个规律具体细节还挺烦的.刚刚偶然看到Q巨在群里提到的他的一个思路,妙啊,很好理解,而且公式写起来也容易.OrzQ巨 #include<bits ...

  4. 多模字符串匹配算法-Aho–Corasick

    背景 在做实际工作中,最简单也最常用的一种自然语言处理方法就是关键词匹配,例如我们要对n条文本进行过滤,那本身是一个过滤词表的,通常进行过滤的代码如下 for (String document : d ...

  5. darknet-yolov3模型预测框size不正确的原因

    问题描述:预测框的中心位置正常,但是预测的框的width和height不正常. 解决方法:使得训练的配置cfg和测试中cfg的输入width, height, anchorbox保持一致! 问题是我在 ...

  6. 【翻译】详解HTML5 自定义 Data 属性

    原标题:HTML5 Custom Data Attributes (data-*) 你是否曾经使用 class 或 rel 来保存任意的元数据,只为了使你的JavaScript更简单?如果你回答是的, ...

  7. [CSP-S模拟测试]:小P的2048(模拟)

    题目描述 最近,小$P$迷上了一款叫做$2048$的游戏.这块游戏在一个$n\times n$的棋盘中进行,棋盘的每个格子中可能有一个形如$2^k(k\in N^*)$的数,也可能是空的.游戏规则介绍 ...

  8. 深入理解JVM虚拟机11:Java内存异常原理与实践

    本文转自互联网,侵删 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutori ...

  9. win10+VS2015+opencv3.4.0配置方法

    win10+VS2015+opencv3.4.0配置方法 操作环境: windows10 64位opencv 3.4.0:https://opencv.org/releases.html(选择open ...

  10. 解决IDEA输入法输入中文候选框不显示问题(亲测谷歌拼音完美解决问题)

    解决方法:关掉idea,进入idea的安装目录找到jre64文件夹重命名为jre642(随便什么名字都行)如下图 然后找到jdk安装目录下的jre文件复制到上图idea的安装目录下并改名为jre64 ...