题目链接  2014 多校1 Problem J

题意  现在有两个账号,初始$rating$都为$0$,现在每次打分比较低的那个,如果进前$200$那么就涨$50$分,否则跌$100$分。

    每一次打进前$200$的概率为$p$,且每一次竞赛是相互独立的。求当一个号打到$1000$分时已经打的期望场数。

把$1000$变成$20$,并且分析出所有有效的状态。

有效的状态一共$211$个。

$(0, 0)$

$(1, 0), (1, 1)$

$(2, 0), (2, 1), (2, 2)$

......

$(19, 0), (19, 1), (19, 2), ..., (19, 19)$

再加一个$(20, 19)$,这是目标状态。

设$f(x, y)$为$(x, y)$状态时所需要到达目标的期望场数。

显然$f(19, 20) = 0$

设$(x, y)$赢了之后状态为$(x1, y1)$, 输了之后状态为$(x2, y2)$

那么$f(x, y) = p*f(x1, y1) + (1-p)*f(x2, y2) + 1$

注意状态$(0, 0)$输了之后还是$(0, 0)$

那么建立211个方程组,高斯消元求解即可。

#include <bits/stdc++.h>

using namespace std;

#define rep(i, a, b)    for (int i(a); i <= (b); ++i)
#define dec(i, a, b) for (int i(a); i >= (b); --i) typedef long long LL; const int N = 235;
const double eps = 1e-12; double a[N][N], x[N], p;
int equ, var;
int c[N][N];
int cnt;
int y; void Gauss(){
int row, col, max_r;
row = col = 0;
while (row < equ && col < var){
max_r = row;
rep(i, row + 1, equ - 1) if (fabs(a[i][col]) - fabs(a[max_r][col]) > eps) max_r = i;
if (max_r != row) rep(j, col, var) swap(a[row][j], a[max_r][j]); if (fabs(a[row][col]) < eps){
col++;
continue;
} rep(i, row + 1, equ - 1){
if (fabs(a[i][col]) > eps){
double t = a[i][col] / a[row][col];
a[i][col] = 0.0;
rep(j, col + 1, var) a[i][j] -= a[row][j] * t;
}
}
row++;
col++;
} dec(i, equ - 1, 0){
if (fabs(a[i][i]) < eps) continue;
double tmp = a[i][var];
rep(j, i + 1, var - 1) tmp -= a[i][j] * x[j];
x[i] = tmp / a[i][i];
}
} int main(){ cnt = 0;
for (int i = 0; i <= 22; ++i){
for (int j = 0; j <= 22; ++j){
c[i][j] = -1e9;
}
} rep(i, 0, 19) rep(j, 0, i) c[i][j] = cnt++;
c[20][19] = cnt++; equ = var = cnt; while (~scanf("%lf", &p)){
memset(a, 0, sizeof a);
rep(i, 0, 19){
rep(j, 0, i - 1){
y = c[i][j];
a[y][y] = 1;
a[y][211] = 1;
a[y][c[i][max(0, j - 2)]] -= (1 - p);
a[y][c[i][j + 1]] -= p;
}
y = c[i][i];
a[y][y] = 1;
a[y][211] = 1;
a[y][c[i][max(0, i - 2)]] -= (1 - p);
a[y][c[i + 1][i]] -= p;
} a[210][210] = 1;
Gauss();
printf("%.6lf\n", x[0]);
} return 0;
}

  

HDU 4870 Rating (高斯消元)的更多相关文章

  1. hdu 4870 rating(高斯消元求期望)

    Rating Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  2. HDU 3949 XOR 高斯消元

    题目大意:给定一个数组,求这些数组通过异或能得到的数中的第k小是多少 首先高斯消元求出线性基,然后将k依照二进制拆分就可以 注意当高斯消元结束后若末尾有0则第1小是0 特判一下然后k-- 然后HDU输 ...

  3. hdu 5755(高斯消元——模线性方程组模板)

    PS. 看了大神的题解,发现确实可以用m个未知数的高斯消元做.因为确定了第一行的情况,之后所有行的情况都可以根据第一行推. 这样复杂度直接变成O(m*m*m) 知道了是高斯消元后,其实只要稍加处理,就 ...

  4. HDU 3949 XOR [高斯消元XOR 线性基]

    3949冰上走 题意: 给你 N个数,从中取出若干个进行异或运算 , 求最后所有可以得到的异或结果中的第k小值 N个数高斯消元求出线性基后,设秩为$r$,那么总共可以组成$2^r$中数字(本题不能不选 ...

  5. Time travel HDU - 4418(高斯消元)

    Agent K is one of the greatest agents in a secret organization called Men in Black. Once he needs to ...

  6. hdu 6465 线性变换高斯消元

    http://acm.hdu.edu.cn/showproblem.php?pid=6465 题意 给你三个点,再给你经过线性变换后的三个点,然后q次询问,给你一个点,需要你输出线性变换后的点 题解 ...

  7. HDU 3364 Lanterns 高斯消元

    Lanterns Problem Description   Alice has received a beautiful present from Bob. The present contains ...

  8. HDU 3915 Game (高斯消元)

    题意:有n堆石子,每个人只能从某一堆至少拿走一个,不能拿者败.问事先拿走某些堆的石子,使得先手必败. 析:将石子拆成二进制,未知数为1表示保留该堆石子,为0表示事先拿走该堆石子.最后求自由变元的数目, ...

  9. HDU 4870 Rating(高斯消元 )

    HDU 4870   Rating 这是前几天多校的题目,高了好久突然听旁边的大神推出来说是可以用高斯消元,一直喊着赶快敲模板,对于从来没有接触过高斯消元的我来说根本就是一头雾水,无赖之下这几天做DP ...

  10. 2014多校第一场J题 || HDU 4870 Rating(DP || 高斯消元)

    题目链接 题意 :小女孩注册了两个比赛的帐号,初始分值都为0,每做一次比赛如果排名在前两百名,rating涨50,否则降100,告诉你她每次比赛在前两百名的概率p,如果她每次做题都用两个账号中分数低的 ...

随机推荐

  1. dfs 的全排列

    #include <iostream> #include <algorithm> #include <cstdio> #include <string> ...

  2. Fibonacci again and again HDU - 1848

    任何一个大学生对菲波那契数列(Fibonacci numbers)应该都不会陌生,它是这样定义的: F(1)=1; F(2)=2; F(n)=F(n-1)+F(n-2)(n>=3); 所以,1, ...

  3. Word 2013发布博客测试

    Hello world ! I am from word2013! 测试修改 这里添加一行文字.   参考 1在 Word 中建立博客的相关帮助 2使用Word2013发布随笔到博客园 PS: 参考2 ...

  4. 「微信小程序免费辅导教程」25,基本内容组件text的使用及个人帐号允许的服务类目

  5. idea 安装findBugs 可以做代码扫描,也可以导出扫描结果生成扫描报告

    idea 安装findBugs 可以做代码扫描,也可以导出扫描结果生成扫描报告 https://my.oschina.net/viakiba/blog/1838296 https://www.cnbl ...

  6. 56、使用android studio(v1.3.*)修改包名 (rename package name)

    一.修改包名 ①选中目录,开始构造 在弹窗中选中Rename directory 在弹窗中选中Rename package 填写新的包名,点击Refactor 如果有警告,不用管它,直接点击Do Re ...

  7. Stephen 博客正式开通 【个人公众号:Stephen 】

    个人博客开通. 个人公众号:Stephen

  8. hibernate 出错 集合

    Lazy="false"反而出错 错误信息: “System.Configuration.ConfigurationErrorsException”类型的异常在 Spring.Co ...

  9. jeakins+maven+jmeter构建性能测试自动化( 在eclipse里运行如果出现没有找到“*.loadtest.xls”,请将此文件名修改为你对应使用的xsl文件名)

    背景: 首先用jmeter录制或者书写性能测试的脚本,用maven添加相关依赖,把性能测试的代码提交到github,在jenkins配置git下载性能测试的代码,配置运行脚本和测试报告,配置运行失败自 ...

  10. jquery操作select(取值,设置选中

    比如<select class="selector"></select> 1.设置value为pxx的项选中 $(".selector" ...