BZOJ3150: [Ctsc2013]猴子
这题好神啊..好神啊..
首先得到简单的DP方程:
$f_{\{ i \}}=\frac{\sum_{i \ne j} f_ {\{ i,j \}} \times P_{(i,j)}}{N-1}$
然后存在这样一个关系:$f_{A \cup B}=f_{A}+f_{B}$。
所以上面那个DP方程就可以很愉悦的改为:
$f_{\{ i \}}=\frac{\sum_{i \ne j} (f_ {\{ i\}} +f_{\{ j \} } )\times P_{(i,j)}}{N-1}$
因为存在相互依赖关系,用高斯消元求解。
然后因为最后为了防止出现所有元素都为$0$的解,需要加上$\sum f_i =1$这一个限制条件。
//BZOJ 3150
//by Cydiater
//2017.1.22
#include <iostream>
#include <queue>
#include <map>
#include <cstdio>
#include <cstring>
#include <string>
#include <ctime>
#include <cmath>
#include <algorithm>
#include <iomanip>
#include <cstdlib>
#include <bitset>
#include <set>
#include <vector>
using namespace std;
#define ll long long
#define up(i,j,n) for(int i=j;i<=n;i++)
#define down(i,j,n) for(int i=j;i>=n;i--)
#define cmax(a,b) a=max(a,b)
#define cmin(a,b) a=min(a,b)
#define db double
const int MAXN=1005;
db M[MAXN][MAXN],P[MAXN][MAXN];
int N,MM;
char s[MAXN];
namespace solution{
void Prepare(){
scanf("%d%d",&N,&MM);
up(i,1,N)up(j,1,N)scanf("%lf",&P[i][j]);
up(i,1,N-1){
M[i][i]=1-N;
up(j,1,N)if(i!=j){
M[i][j]+=P[i][j];
M[i][i]+=P[i][j];
}
}
up(i,1,N+1)M[N][i]=1;
}
void Guass(){
int waited;
up(i,1,N){
waited=i;
up(j,i+1,N)if(abs(M[j][i])>abs(M[waited][i]))waited=j;
if(i!=waited)up(j,i,N+1)swap(M[waited][j],M[i][j]);
up(j,i+1,N){
db f=M[j][i]/M[i][i];
up(k,i,N+1)M[j][k]-=f*M[i][k];
}
}
down(i,N,1){
up(j,i+1,N)M[i][N+1]-=M[i][j]*M[j][N+1];
M[i][N+1]/=M[i][i];
}
}
void Solve(){
Guass();
while(MM--){
scanf("%s",s);
int len=strlen(s);
db ans=0;
up(i,0,len)if(s[i]=='1')ans+=M[i+1][N+1];
printf("%.8lf\n",ans);
}
}
}
int main(){
//freopen("input.in","r",stdin);
using namespace solution;
Prepare();
Solve();
return 0;
}
BZOJ3150: [Ctsc2013]猴子的更多相关文章
- [BZOJ3150][Ctsc2013]猴子 期望dp+高斯消元
3150: [Ctsc2013]猴子 Time Limit: 20 Sec Memory Limit: 256 MBSec Special JudgeSubmit: 163 Solved: 10 ...
- BZOJ 3150 [Ctsc2013]猴子 ——期望DP 高斯消元
一堆牌的期望等于每张牌的期望值和. 考虑三个人的游戏即可得到. 然后每张牌遇到另外一张的概率相同,然后就可以列方程求解了. #include <cmath> #include <cs ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- 《饥荒游戏》SW BUG 刷猴子 & 刷淘气值 办法
简介 该办法利用刷猴子的方式,通过杀猴子获取淘气值,从而刷出坎普斯,继而刷坎普斯背包 物品准备 灭火器x1 箱子x1 逗猴球x1 猴窝xN 帽贝岩x2 避雷针x1 操作步骤 1.灭火器建造在2个帽贝岩 ...
- c语言经典算法——猴子偷桃问题
题目:海滩上有一堆桃子,五只猴子来分.第一只猴子把这堆桃子凭据分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份.第二只猴子把剩下的桃子又平均分成五份,又多了一个,它同样把多的一个扔入海中,拿 ...
- 网络神器Greasemonkey(油猴子)使用方法简介+脚本分享【转载】
推荐下,觉得这个方法有用, 今天艾薇百科来介绍一下功能强大的Greasemonkey,俗称"油猴子",Greasemonkey可以自由定制网页,实现你想要的各种功能.堪称" ...
- sicily 猴子选大王
题目描述 猴子选大王,有N只猴子,从1-N进行编号.它们按照编号的顺时针方向,排成一个圆圈,然后从第一只猴子开始报数.第一只猴子报1,以后每只猴子报的数字都是它前面猴子所报数字加1.如果一只猴子报的数 ...
- 踩个猴尾不容易啊 Canvas画个猴子
踩个猴尾不容易啊 Canvas画个猴子 <!DOCTYPE html> <html> <head> <meta charset="UTF-8&qu ...
- BZOJ2429[HAOI2006]聪明的猴子[最小生成树 kruskal]
2429: [HAOI2006]聪明的猴子 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 896 Solved: 575[Submit][Statu ...
随机推荐
- json学习之JSONArray的应用(转载)
从json数组中得到相应java数组,如果要获取java数组中的元素,只需要遍历该数组. 1 /** 2 * 从json数组中得到相应java数组 3 * JSONArray下的toArray()方法 ...
- Python--进阶处理4
#================第四章:迭代器和生成器=================== # 函数 itertools.islice()适用于在迭代器和生成器上做切片操作. import ite ...
- jstree的checkbox实例+详解
jstree的checkbox实例较少,思索后决定进行一下整理,先上代码 $("#filtrate_row").on("loaded.jstree",funct ...
- WARNING:tensorflow:From /usr/lib/python2.7/site-packages/tensorflow/python/util/tf_should_use.py:189: initialize_all_variables (from tensorflow.python.ops.variables) is deprecated and will be removed
initialize_all_variables已被弃用,将在2017-03-02之后删除. 说明更新:使用tf.global_variables_initializer代替. 就把tf.initia ...
- 剑指Offer——整数中1出现的次数(从1到n整数中1出现的次数)
题目描述: 求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1.10.11.12.13因此共出现6次,但是对于后面问题他就没辙了 ...
- Mysql日常操作
创建用户并授权 grant all privileges on test.* to "test"@"localhost" identified by " ...
- d3.js:数据可视化利器之 交互行为:响应DOM事件
selection.on:事件监听操作符 on()操作符可以添加或移除选择集中每个 DOM元素的事件监听函数: selection.on(type[,listener[,capture]]) 参数ty ...
- Buy the souvenirs---hdu2126(01背包输出方案数)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2126 有n个物品每个物品的价格是v[i],现在有m元钱问最多买多少种物品,并求出有多少种选择方法: 如 ...
- 安全篇:弱密码python检测工具
安全篇:弱密码python检测工具 https://github.com/penoxcn/PyWeakPwdAudit
- Mozilla Network Security Services拒绝服务漏洞
解决办法: 运行 yum update nss yum update nss