1. 程式人生 > >LightOJ 1027 A Dangerous Maze 概率期望

LightOJ 1027 A Dangerous Maze 概率期望

但是 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>
#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; 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; }
View Code

技術分享
#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 概率期望