• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            pku2151 Check the difficulty of problems 概率DP,可惡的StreamTokenizer!!!!!

            好吧,這道題思想開始就想到了,結果做的搓死了。。
            題意是這樣,ACM比賽,T個隊,M個題,第i個隊做出第j個題的概率為pi,j,求所有隊至少做一題并且冠軍隊(可能有多個隊)做出N題以上的概率
            首先,每個隊是獨立的。
            設dp[i][j]為前i個題目做出j題的概率,有dp方程dp[i][j]=dp[i-1][j-1]*(p[pos][i])+dp[i-1][j]*(1-p[pos][i])
            邊界條件:dp[0][0]=0;dp[i][0]=dp[i-1][0]*(1-p[pos][i])
            然后結果應該是每隊至少做出一題的概率減去在這個基礎上所有隊做題數小于N的概率。
            萬惡的StreamTokenizer,不知道讀入數據的時候出了什么詭異的問題,對照標程對拍,就是沒錯誤,一提交就WA!最后換Scanner,順利AC。。無語。
            比賽的時候知道了,數據比較大或者浮點的情況下還是別用StreamTokenizer了。。
             1import java.io.*;
             2import java.text.DecimalFormat;
             3import java.util.Arrays;
             4import java.util.Scanner;
             5public class Main {
             6
             7    /**
             8     * @param args
             9     */

            10
            11    static double dp[][]=new double[35][35],map[][]=new double[1001][31];
            12    static int m,t,n;
            13    public static void main(String[] args) throws Exception{
            14        Scanner in=new Scanner(System.in);
            15        while(true)
            16        {
            17            m=in.nextInt();t=in.nextInt();n=in.nextInt();
            18            if(m==0&&t==0&&n==0break;
            19            for(int i=1;i<=t;i++)
            20                for(int j=1;j<=m;j++)
            21                    map[i][j]=in.nextDouble();
            22            double total=1.0,minus=1.0;
            23            for(int i=1;i<=t;i++)
            24            {
            25                for(int j=0;j<=m;j++)
            26                    Arrays.fill(dp[j],0.0);
            27                double t1=0.0,t2=0.0;
            28                dp[0][0]=1.0;
            29                for(int j=1;j<=m;j++)
            30                {
            31                    dp[j][0]=dp[j-1][0]*(1-map[i][j]);
            32                    for(int k=1;k<=m;k++)
            33                        dp[j][k]=dp[j-1][k-1]*map[i][j]+dp[j-1][k]*(1-map[i][j]);
            34                }

            35                for(int j=1;j<=m;j++)
            36                {
            37                    t1+=dp[m][j];
            38                    t2+=(j<n?dp[m][j]:0);
            39                }

            40                    
            41                total*=t1;
            42                minus*=t2;
            43            }

            44            System.out.printf("%.3f\n",total-minus);
            45        }

            46
            47    }

            48
            49}

            50

            posted on 2010-11-02 01:23 yzhw 閱讀(199) 評論(0)  編輯 收藏 引用 所屬分類: DPcombination math

            <2010年11月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久精品国产精品青草 | 精品久久久久久久无码| 亚洲精品无码久久久久去q | 亚洲色欲久久久综合网| 国产人久久人人人人爽| 狠狠精品久久久无码中文字幕| 日韩中文久久| 国产成人久久激情91| 欧美午夜A∨大片久久 | 久久精品无码一区二区日韩AV| 最新久久免费视频| 久久最新精品国产| 综合人妻久久一区二区精品| 久久se精品一区二区| 伊人久久大香线蕉AV一区二区| 久久国产精品-久久精品| 久久久精品国产| 国产高清美女一级a毛片久久w | 97久久婷婷五月综合色d啪蜜芽 | 精品一久久香蕉国产线看播放| 少妇人妻88久久中文字幕| 久久高清一级毛片| 99久久精品国产免看国产一区| 久久综合久久美利坚合众国| 国产精品美女久久久久av爽| 九九99精品久久久久久| 亚洲女久久久噜噜噜熟女| 亚洲人成电影网站久久| 久久精品亚洲乱码伦伦中文| 国产69精品久久久久777| 久久精品毛片免费观看| 天天躁日日躁狠狠久久| 97精品伊人久久久大香线蕉| 久久久久久免费视频| 亚洲精品tv久久久久| 国产精品亚洲美女久久久| 91精品国产91久久久久久| 久久精品一区二区国产| 亚洲国产精品久久久久婷婷老年| 国产精品久久毛片完整版| 东京热TOKYO综合久久精品|