LightOJ 1027 A Dangerous Maze 概率期望
阿新 • • 發佈:2017-09-14
但是 scan 公式 錯誤代碼 temp size 如果 gcd code
題目鏈接: https://vjudge.net/problem/LightOJ-1027
題目描述: 有N個門, 每個門的選擇是等概率的, 如果選擇到正數, 我將在正數秒後逃出迷宮, 如果是負數就重新選, 問逃離的期望時間是多少
解題思路: 我這道題犯蠢了, 我認為是.....說不太明白, 看程序吧, 一下子就能看懂, 其中涉及到了一個約分, 但是我沒想到就算是long long 也會溢出, 那麽我將約分放進每次mul中呢? 也是不行的, 因為都是素數呢, 不是一樣會溢出? 自己在半個小時後才意識到這個蠢問題.........
正確解法是 Y = P1 * T1 + P2 * (T2 + Y) 移項就可以整理出Y = 正數個數的倒數 * ∑abs(Xi) , 再將0的情況單獨扣出去就可以了
代碼: 下面第一個是我的錯誤代碼, 謹記
#include <iostream> #include <cstdio> #include <string> #include <vector> #include <cstring> #include <iterator> #include <cmath> #include <algorithm> #include <stack> #include <deque> #include <map> #includeView Code<set> #include <queue> #define lson l, m, rt<<1 #define rson m+1, r, rt<<1|1 #define mem0(a) memset(a,0,sizeof(a)) #define mem1(a) memset(a,-1,sizeof(a)) #define sca(x) scanf("%d",&x) //#define de printf("=======\n") typedef long long ll; using namespace std; ll x[103]; ll gcd(ll a, ll b) {return b==0 ? a : gcd(b, a%b); } struct node { ll nu; ll de; node() { nu = de = 1; } void mul(ll x, ll y) { nu *= x; de *= y; ll g = gcd(nu, de); nu /= g, de /= g; } void sim() { ll g = gcd(nu, de); nu /= g, de /= g; } }; int main() { int t; sca(t); int cases = 1; while( t-- ) { ll n; scanf( "%lld", &n ); ll cnt = 0; ll sum = 0; for( int i = 0; i < n; i++ ) { scanf( "%lld", &x[i] ); if( x > 0 ) { sum += x[i]; cnt++; } } if( cnt == 0 ) { printf( "Case %d: inf\n", cases++ ); continue; } else if( cnt == n ) { node temp; for( ll i = 0; i < n; i++ ) { temp.mul(x[i], n); } if( temp.nu == 0 || temp.de == 0 ) while(1) {} temp.sim(); printf( "Case %d: %lld/%lld\n", cases++, temp.nu, temp.de ); continue; } node res; res.mul(sum*n, cnt); res.mul(n-cnt, cnt); res.sim(); printf( "Case %d: %lld/%lld\n", cases++, res.nu, res.de ); } return 0; }
#include <iostream> #include <cstdio> #include <string> #include <vector> #include <cstring> #include <iterator> #include <cmath> #include <algorithm> #include <stack> #include <deque> #include <map> #include <set> #include <queue> #define lson l, m, rt<<1 #define rson m+1, r, rt<<1|1 #define mem0(a) memset(a,0,sizeof(a)) #define mem1(a) memset(a,-1,sizeof(a)) #define sca(x) scanf("%d",&x) //#define de printf("=======\n") typedef long long ll; using namespace std; int gcd(int a, int b) { return b == 0 ? a : gcd(b, a%b); } int main() { int t; sca(t); int cases = 1; while( t-- ) { int n; sca(n); int sum = 0; int cnt = 0; for( int i = 0; i < n; i++ ) { int x; sca(x); sum += abs(x); if( x > 0 ) cnt++; } if( cnt == 0 ) { printf( "Case %d: inf\n", cases++ ); continue; } int g = gcd(sum, cnt); sum /= g; cnt /= g; printf( "Case %d: %d/%d\n", cases++, sum, cnt ); } return 0; }AC
思考: 在想算法之後, 在寫代碼之前一定要這個算法代碼到底能不能實現, 像我這個De了半個多小時的BUG才發現算法能算出來, 就是無法實現, 以後先公式, 看能不能公式出來, 概率題好多都是這樣的
LightOJ 1027 A Dangerous Maze 概率期望