HDOJ 4576
来源:互联网 发布:淘宝信用贷款逾期一天 编辑:程序博客网 时间:2024/06/05 18:22
Robot
Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 102400/102400 K (Java/Others)Total Submission(s): 1216 Accepted Submission(s): 470
Problem Description
Michael has a telecontrol robot. One day he put the robot on a loop with n cells. The cells are numbered from 1 to n clockwise.
At first the robot is in cell 1. Then Michael uses a remote control to send m commands to the robot. A command will make the robot walk some distance. Unfortunately the direction part on the remote control is broken, so for every command the robot will chose a direction(clockwise or anticlockwise) randomly with equal possibility, and then walk w cells forward.
Michael wants to know the possibility of the robot stopping in the cell that cell number >= l and <= r after m commands.
At first the robot is in cell 1. Then Michael uses a remote control to send m commands to the robot. A command will make the robot walk some distance. Unfortunately the direction part on the remote control is broken, so for every command the robot will chose a direction(clockwise or anticlockwise) randomly with equal possibility, and then walk w cells forward.
Michael wants to know the possibility of the robot stopping in the cell that cell number >= l and <= r after m commands.
Input
There are multiple test cases.
Each test case contains several lines.
The first line contains four integers: above mentioned n(1≤n≤200) ,m(0≤m≤1,000,000),l,r(1≤l≤r≤n).
Then m lines follow, each representing a command. A command is a integer w(1≤w≤100) representing the cell length the robot will walk for this command.
The input end with n=0,m=0,l=0,r=0. You should not process this test case.
Each test case contains several lines.
The first line contains four integers: above mentioned n(1≤n≤200) ,m(0≤m≤1,000,000),l,r(1≤l≤r≤n).
Then m lines follow, each representing a command. A command is a integer w(1≤w≤100) representing the cell length the robot will walk for this command.
The input end with n=0,m=0,l=0,r=0. You should not process this test case.
Output
For each test case in the input, you should output a line with the expected possibility. Output should be round to 4 digits after decimal points.
Sample Input
3 1 1 215 2 4 4120 0 0 0
Sample Output
0.50000.2500
Source
2013ACM-ICPC杭州赛区全国邀请赛
直接去模拟即可,滚动数组。
#include <cstdio>#include <cmath>#include <algorithm>#include <iostream>#include <cstring>#include <map>#include <string>#include <stack>#include <cctype>#include <vector>#include <queue>#include <set>using namespace std;//#define Online_Judge#define outstars cout << "***********************" << endl;#define clr(a,b) memset(a,b,sizeof(a))#define lson l , mid , rt << 1#define rson mid + 1 , r , rt << 1|1#define FOR(i , x , n) for(int i = (x) ; i < (n) ; i++)#define FORR(i , x , n) for(int i = (x) ; i <= (n) ; i++)#define REP(i , x , n) for(int i = (x) ; i > (n) ; i--)#define REPP(i ,x , n) for(int i = (x) ; i >= (n) ; i--)#define mid ((l + r) >> 1)#define mk make_pairconst int MAXN = 100000 + 100;const int maxw = 10000000 + 20;const int MAXNNODE = 10000 +10;const long long LLMAX = 0x7fffffffffffffffLL;const long long LLMIN = 0x8000000000000000LL;const int INF = 0x7fffffff;const int IMIN = 0x80000000;#define eps 1e-8#define mod 10007typedef long long LL;const double PI = acos(-1.0);typedef double D;typedef pair<int , int> pii;D f[2][210];int main(){ //ios::sync_with_stdio(false);#ifdef Online_Judge freopen("in.txt","r",stdin); freopen("out.txt","w",stdout);#endif // Online_Judge int n , m , l , r , w; while(~scanf("%d%d%d%d" , &n , &m , &l , &r) , n) { int now = 0; clr(f[0] , 0); f[0][1] = 1; FORR(k , 1 , m) { scanf("%d", &w); now ^= 1; FORR(i , 1 , n)///逆时针为减w,顺时针为加w { f[now][i] = (f[now ^ 1][i - w + (i - w >= 1 ? 0 : n)] + f[now ^ 1][i + w - (i + w <= n ? 0 : n)]) * 0.5; } } D ans = 0; FORR(i , l , r)ans += f[now][i]; FORR(i , 0 , n)printf(" %lf %lf\n",f[0][i] , f[1][i]); printf("%.4lf\n" , ans); } return 0;}
- HDOJ 4576
- HDOJ
- hdoj
- hdoj
- HDOJ
- hdoj 1568 && hdoj 5344 && hdoj 5444
- HDOJ 4576/2013年杭州邀请赛A题 Robot 暴力~
- HDOJ 2176
- Hdoj--1272
- hdoj 1003
- hdoj 1005
- hdoj 1030
- hdoj 2154
- hdoj 2100
- HDOJ 1106
- hdoj 1257
- hdoj 1159
- hdoj 1160
- SVN中的Import
- 实现设计模式:工厂模式
- Android 内存优化
- 织梦当前位置不显示最后一个符号
- Android混淆注意事项
- HDOJ 4576
- NAND FLASH扇区管理及初始化
- EOS开发五
- 砖6 内核线程的创建 kthread_create
- 哲学家进餐问题
- mysql常用语句
- iPhone平台下基于XMPP的IM研究
- my html
- char* 和char[]的区别