博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVA 1541 - To Bet or Not To Bet(概率递推)
阅读量:6093 次
发布时间:2019-06-20

本文共 1469 字,大约阅读时间需要 4 分钟。

UVA 1541 - To Bet or Not To Bet

题意:这题题意真是神了- -。看半天,大概是玩一个游戏,開始在位置0。终点在位置m + 1,每次扔一个硬币,正面走一步,反面走两步,走到的步上有4种情况:

1、向前走n步
2、向后走n步
3、停止一回合
4、无影响

问能在t次机会内,走到终点m + 1(假设跃过也算走到了)的概率。大于0.5。等于0.5,小于0.5相应不同输出

思路:题意懂了就好办了。事实上就是递推就能够了dp[i][j]表示第i次机会,落在j步的概率。然后不断一步步去递推就可以

代码:

#include 
#include
#include
using namespace std;const int INF = 0x3f3f3f3f;const int N = 55;int T, m, t, to[N];double dp[N][N];int tra() { char str[10]; scanf("%s", str); if (str[0] == '0') return 0; if (str[0] == 'L') return INF; else { int num = 0, flag = (str[0] == '+' ?

1 : -1); for (int i = 1; str[i]; i++) num = num * 10 + str[i] - '0'; return num * flag; } } int main() { scanf("%d", &T); while (T--) { scanf("%d%d", &m, &t); for (int i = 1; i <= m; i++) to[i] = tra(); to[m + 1] = 0; memset(dp, 0, sizeof(dp)); dp[0][0] = 1; for (int i = 0; i <= t; i++) { for (int j = 0; j <= m; j++) { if (to[min(m + 1, j + 1)] == INF) dp[i + 2][min(m + 1, j + 1)] += dp[i][j] * 0.5; else dp[i + 1][min(max(0, j + 1 + to[min(m + 1, j + 1)]), m + 1)] += dp[i][j] * 0.5; if (to[min(m + 1, j + 2)] == INF) dp[i + 2][min(m + 1, j + 2)] += dp[i][j] * 0.5; else dp[i + 1][min(max(0, j + 2 + to[min(m + 1, j + 2)]), m + 1)] += dp[i][j] * 0.5; } } double ans = 0; for (int i = 0; i <= t; i++) ans += dp[i][m + 1]; if (ans > 0.5) printf("Bet for. "); else if (ans < 0.5) printf("Bet against. "); else printf("Push. "); printf("%.4lf\n", ans); } return 0; }

转载地址:http://ntgwa.baihongyu.com/

你可能感兴趣的文章
Codeforces 520B:Two Buttons(思维,好题)
查看>>
web框架-(二)Django基础
查看>>
Jenkins持续集成环境部署
查看>>
emoji等表情符号存mysql的方法
查看>>
Excel到R中的日期转换
查看>>
检查磁盘利用率并且定期发送告警邮件
查看>>
MWeb 1.4 新功能介绍二:静态博客功能增强
查看>>
linux文本模式和文本替换功能
查看>>
Windows SFTP 的安装
查看>>
摄像机与绕任意轴旋转
查看>>
rsync 服务器配置过程
查看>>
预处理、const与sizeof相关面试题
查看>>
爬虫豆瓣top250项目-开发文档
查看>>
Elasticsearch增删改查
查看>>
oracle归档日志增长过快处理方法
查看>>
有趣的数学书籍
查看>>
teamviewer 卸载干净
查看>>
多线程设计模式
查看>>
解读自定义UICollectionViewLayout--感动了我自己
查看>>
SqlServer作业指定目标服务器
查看>>