codeforces24D
CF24D Broken robot
题目背景
小小迪带你吃瓜
题目描述
给出一个 n×m 的矩阵区域,一个机器人初始在第 x 行第 y 列,每一步机器人会等概率 的选择停在原地,左移一步,右移一步,下移一步,如果机器人在边界则丌会往区域外移动, 问机器人到达最后一行的期望步数。
输入输出格式
输入格式:
第一行两个整数,分别表示 n 和 m。 第二行两个整数,分别表示 x 和 y
输出格式:
一个小数表示答案
输入输出样例
10 10
10 4
0.0000000000
10 14
5 14
18.0038068653 sol:肯定是dp辣,状态呼之欲出了,dp[i][j]表示从位置i,j到最后一行的期望步数
转移也十分容易(但是不能直接转移,因为是几个方程组,要用高斯消元解出来)
前面带-->表示这是用来消元的方程
dp[i][1]=1/3*(dp[i][1]+dp[i][2]+dp[i+1][1])+1 (1)
--> dp[i][1] - 1/3*dp[i][1] - 1/3*dp[i][2] = 1/3*dp[i+1][1]+1
dp[i][j]=1/4*(dp[i][j]+dp[i][j-1]+dp[i][j+1]+dp[i+1][j])+1 (2~m-1)
--> dp[i][j] - 1/4*dp[i][j] - 1/4*dp[i][j-1] - 1/4*dp[i][j+1] = 1/4*dp[i+1][j]+1
dp[i][m]=1/3*(dp[i][m]+dp[i][m-1]+dp[i+1][m])+1 (m)
--> dp[i][m]-1/3*dp[i][m]-1/3*dp[i][m-1] = 1/3*dp[i+1][m]+1
但是直接解是n3的,会T出屎,但是这个每行最多就3个不为0的系数,所以O(n)推过去,求出最后一个,在推回来即可
/*
dp[i][1]=1/3*(dp[i][1]+dp[i][2]+dp[i+1][1])+1 (1)
--> dp[i][1] - 1/3*dp[i][1] - 1/3*dp[i][2] = 1/3*dp[i+1][1]+1
dp[i][j]=1/4*(dp[i][j]+dp[i][j-1]+dp[i][j+1]+dp[i+1][j])+1 (2~m-1)
--> dp[i][j] - 1/4*dp[i][j] - 1/4*dp[i][j-1] - 1/4*dp[i][j+1] = 1/4*dp[i+1][j]+1
dp[i][m]=1/3*(dp[i][m]+dp[i][m-1]+dp[i+1][m])+1 (m)
--> dp[i][m]-1/3*dp[i][m]-1/3*dp[i][m-1] = 1/3*dp[i+1][m]+1
*/
#include <bits/stdc++.h>
using namespace std;
typedef int ll;
inline ll read()
{
ll s=;
bool f=;
char ch=' ';
while(!isdigit(ch))
{
f|=(ch=='-'); ch=getchar();
}
while(isdigit(ch))
{
s=(s<<)+(s<<)+(ch^); ch=getchar();
}
return (f)?(-s):(s);
}
#define R(x) x=read()
inline void write(ll x)
{
if(x<)
{
putchar('-'); x=-x;
}
if(x<)
{
putchar(x+''); return;
}
write(x/);
putchar((x%)+'');
return;
}
#define W(x) write(x),putchar(' ')
#define Wl(x) write(x),putchar('\n')
const int N=;
int X,Y;
double dp[N][N];
double a[N][N],b[N];
inline void Debug(int n)
{
int i,j;
for(i=;i<=n;i++)
{
for(j=;j<=n;j++) printf("%.3lf ",a[i][j]);
printf("%.3lf\n",b[i]);
}
}
inline void Gauss(int n)
{
int i;
double Div;
// Debug(n);
for(i=;i<=n;i++)
{
double Div=a[i][i];
a[i][i]/=Div; b[i]/=Div;
if(i==n) break;
a[i][i+]/=Div;
Div=a[i+][i]/a[i][i];
a[i+][i]-=Div*a[i][i];
a[i+][i+]-=Div*a[i][i+];
b[i+]-=Div*b[i];
}
for(i=n-;i>=;i--) b[i]-=b[i+]*a[i][i+];
}
int main()
{
int i,j,n,m;
R(n); R(m); R(X); R(Y);
for(i=;i<=m;i++) dp[n][i]=.;
for(i=n-;i>=X;i--)
{
if(m!=)
{
a[][]=./.; a[][]=-./.; b[]=./.*dp[i+][]+.;
}
else
{
a[][]=./.; b[]=./.*dp[i+][]+;
}
for(j=;j<m;j++)
{
a[j][j]=./.; a[j][j-]=-./.; a[j][j+]=-./.; b[j]=./.*dp[i+][j]+.;
}
if(m>)
{
a[m][m]=./.; a[m][m-]=-./.; b[m]=./.*dp[i+][m]+.;
}
Gauss(m);
for(j=;j<=m;j++) dp[i][j]=b[j];
}
printf("%.10lf\n",dp[X][Y]);
return ;
}
/*
input
10 10
10 4
output
0.0000000000 input
10 14
5 14
output
18.0038068653 input
2 1
1 1
output
2.0000000000
*/
codeforces24D的更多相关文章
随机推荐
- face detection[HR]
该模型hybrid-resolution model (HR),来自<finding tiny faces>,时间线为2016年12月 0 引言 虽然大家在目标识别上有了较好的进步,可是检 ...
- numpy.loadtxt()
简介 np.loadtxt()用于从文本加载数据. 文本文件中的每一行必须含有相同的数据. loadtxt(fname, dtype=<class 'float'>, comments=' ...
- kafka原理和实践(三)spring-kafka生产者源码
系列目录 kafka原理和实践(一)原理:10分钟入门 kafka原理和实践(二)spring-kafka简单实践 kafka原理和实践(三)spring-kafka生产者源码 kafka原理和实践( ...
- 网络爬虫之Url含有中文如何转码
一:背景 今天在使用Jsoup对一个网站进行数据爬取,发现爬取内容为该搜索结果是0条,请求头啥的都填好,利用Chrome开发者工具发现请求Url路径不含中文,抱着试一试的态度,我复制此段非中文参数进行 ...
- NO NEWS IS GOOD NEWS
从客户那传来一个噩耗:要求每个表单在保存之后,要在页面上弹一个 “ 保存成功 ” 的对话框. 客户代表志得意满地说这样用户体验更好,略带谴责意味地傲娇道,“你们早该想到的”.呵呵…… 可不是嘛,我刚入 ...
- python读取/创建XML文件
Python中定义了很多处理XML的函数,如xml.dom,它会在处理文件之前,将根据xml文件构建的树状数据存在内存.还有xml.sax,它实现了SAX API,这个模块牺牲了便捷性,换取了速度和减 ...
- codeforces#1090 D. New Year and the Permutation Concatenation(打表找规律)
题意:给出一个n,生成n的所有全排列,将他们按顺序前后拼接在一起组成一个新的序列,问有多少个长度为n的连续的子序列和为(n+1)*n/2 题解:由于只有一个输入,第一感觉就是打表找规律,虽然表打出来了 ...
- java中流的简单小结
1.分类 按字节流分: InputStream(输出流) OutputStream(输入流) 按字符流分: Reader Writer 提示:输入.输出是站在程序的角度而言,所有输入流是“读 ...
- 在网站开发时,可以设置防盗,不被复制和F12
禁止小功能 //禁止右键 document.oncontextmenu = function () { return false } //禁止f12 document.onkeydown = func ...
- h5小功能_classList和自定义属性data
###1.classList返回一个对象集 通过obj.classList.add()或obj.classList.remove()可操作对象的class属性值 classList.toggle( ) ...