• <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 閱讀(209) 評論(0)  編輯 收藏 引用 所屬分類: DPcombination math

            <2010年12月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久久久久久91精品免费观看| 久久国产精品成人免费| 女人高潮久久久叫人喷水| 久久婷婷五月综合国产尤物app| 亚洲国产视频久久| 狠色狠色狠狠色综合久久| 成人亚洲欧美久久久久| 亚洲香蕉网久久综合影视| 狠狠色婷婷综合天天久久丁香 | 久久亚洲熟女cc98cm| 亚洲色婷婷综合久久| 国产免费久久精品丫丫| 99久久国产宗和精品1上映| 99国内精品久久久久久久| 无码久久精品国产亚洲Av影片 | 国产亚洲成人久久| 久久超乳爆乳中文字幕| 日韩中文久久| Xx性欧美肥妇精品久久久久久| 久久精品桃花综合| 久久精品成人免费观看97| 久久午夜伦鲁片免费无码| 亚洲国产精品无码久久青草| 国产精品欧美亚洲韩国日本久久| 三上悠亚久久精品| 亚洲va中文字幕无码久久| 青青草原综合久久大伊人| 久久久久久久国产免费看| 成人国内精品久久久久影院VR| 久久人爽人人爽人人片AV| 99精品国产99久久久久久97| 久久亚洲AV无码西西人体| 国产精品成人无码久久久久久 | 久久99精品国产自在现线小黄鸭| 狠狠色丁香久久婷婷综合蜜芽五月| 久久久久九九精品影院| 人妻精品久久久久中文字幕| 午夜视频久久久久一区 | 久久精品国产精品亚洲精品| 免费无码国产欧美久久18| 久久精品视频一|