• <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

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            国产亚洲精品自在久久| 国产精品欧美亚洲韩国日本久久| 一本久久免费视频| 亚洲AV无码1区2区久久| 久久亚洲欧美日本精品| 亚洲精品综合久久| 久久精品国产亚洲网站| yy6080久久| 国内精品久久久久久久涩爱 | 色妞色综合久久夜夜| 国产精品久久一区二区三区| 中文字幕久久亚洲一区| 国产精品久久久久一区二区三区| 亚洲综合伊人久久综合| 青青青青久久精品国产h久久精品五福影院1421| 久久久久久久久久久| 久久久久亚洲AV成人网| 国产亚洲欧美成人久久片| 蜜桃麻豆WWW久久囤产精品| 国产女人aaa级久久久级| 狠狠色丁香久久综合婷婷| 亚洲AV无码久久精品狠狠爱浪潮| 亚洲国产成人乱码精品女人久久久不卡 | avtt天堂网久久精品| 国产色综合久久无码有码| 香蕉99久久国产综合精品宅男自| 青青青青久久精品国产| 国产成人精品久久二区二区| 亚洲国产精品成人久久| 精品国产乱码久久久久软件| 久久毛片一区二区| 合区精品久久久中文字幕一区| 久久人妻少妇嫩草AV无码蜜桃| 丁香五月综合久久激情| 久久精品亚洲福利| 人人狠狠综合88综合久久| 少妇久久久久久被弄到高潮 | 久久国产精品久久国产精品| 99久久er这里只有精品18| 久久精品国产精品青草| 国产精品欧美亚洲韩国日本久久 |