题目链接  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. North American Invitational Programming Contest (NAIPC) 2017

    (待补) A. Pieces of Parentheses 将括号处理完成后排序,方式参加下面的博客.然后做一遍背包即可. 2018 Multi-University Training Contest ...

  2. Redis实现之字符串

    简单动态字符串 Redis中的字符串并不是传统的C语言字符串(即字符数组,以下简称C字符串),而是自己构建了一种简单动态字符串(simple dynamic string,SDS),并将SDS作为Re ...

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

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

  4. django 自定义过滤器中的坑.

    今天在创建自定义过滤器的时候,设置已正常.但是在运行后报: 'filter' is not a valid tag library: Template library filter not found ...

  5. 项目管理者必知:适用于仪表盘项目的7个优秀JavaScript库

    仪表盘是用于目标或业务流程的视觉指示工具,也用于切割杂乱无章的数据,从而分割出要点的重要工具.它可以帮助评估信息并及时做出正确的决定,一款实时可视化的仪表盘通常由图标.测绘图.图形符号以及数据表格等组 ...

  6. 使用charles进行https抓包

    一.charles电脑端设置 1.在Charles的菜单栏上选择"Proxy"->"Proxy Settings",填入代理端口8888(这个端口不一定填 ...

  7. 解决pymysql不能实时查询最新的数据

    #在网上查询到的原因为: InnoDB 的默认隔离级别.它可以防止任何被查询的行被其他事务更改,从而阻止不可重复的读取,而不是 幻读取.它使用中度严格的锁定策略,以便事务内的所有查询都会查看同一快照中 ...

  8. 基于web自动化测试框架的设计与开发(讲解演示PPT)

  9. python 类中__init__,__new__,__class__的使用详解

    1.python中所有类默认继承object类,而object类提供了很多原始的内置属性和方法,所有用户定义的类在python 中也会继承这些内置属性.我们可以通过dir()进行查看.虽然python ...

  10. web项目中各种路径的获取(复制,为以后好找资源)

    web项目中各种路径的获取 1.可以在servlet的init方法里 String path = getServletContext().getRealPath("/"); 这将获 ...