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

            pku1202 Family DAG圖上的概率DP

            題意:
            給出N個怪物的家譜樹,求M對怪物間的相關度。怪物可能一夫多妻或一妻多夫,也可以隔代交配。

            給力條件:DAG

            解法:
            眾所周知,DP有兩種推理方法:第i個狀態能推出哪些狀態以及第i個狀態可以由哪些狀態得出,本題必須使用第二種方案
            dp[pos][i],i=1..n為第pos個節點與其前趨(包括間接)節點間的相關度。
            狀態轉移即為dp[pos][i]=sum(dp[p][i]*0.5),p為pos的直接前驅趨節點。
            這題POJ好詭異,死都過不去,但是在小poj(poj.grids.cn),和zju上都沒問題。可能將遞歸改成拓撲序上的迭代就可以了。不過我懶,不想動- -

            代碼:

             1import java.io.*;
             2import java.util.*;
             3import java.math.*;
             4public class Main {
             5    static int nxt[][]=new int[305][305];
             6    static BigDecimal dp[][]=new BigDecimal[305][305],two=BigDecimal.ONE.add(BigDecimal.ONE);
             7    static int n=0,m=0;
             8    static boolean used[]=new boolean[305];
             9    static StreamTokenizer in=new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
            10    static int nextInt() throws IOException
            11    {
            12        in.nextToken();
            13        return (int)in.nval;
            14    }

            15    static void dfs(int pos)
            16    {
            17        if(used[pos]) return;
            18        used[pos]=true;
            19        
            20        for(int j=0;j<2&&nxt[pos][j]!=-1;j++)
            21        {
            22            int p=nxt[pos][j];
            23            dfs(p);
            24            for(int i=1;i<=n;i++)  {dp[pos][i]=dp[pos][i].add(dp[p][i].divide(two));dp[i][pos]=dp[pos][i];}
            25        }

            26        dp[pos][pos]=BigDecimal.ONE;
            27    }

            28    public static void main(String[] args) throws IOException{
            29        n=nextInt();
            30         m=nextInt();
            31        nxt=new int[n+1][2];
            32        used=new boolean[n+1];
            33        dp=new BigDecimal[n+1][n+1];
            34        for(int i=1;i<=n;i++)
            35        {
            36            Arrays.fill(dp[i],BigDecimal.ZERO);
            37            Arrays.fill(nxt[i],-1);
            38        }

            39        Arrays.fill(used, false);
            40        for(int i=0;i<m;i++)
            41        {
            42            int a=nextInt(),b=nextInt(),c=nextInt();
            43            nxt[a][0]=b;
            44            nxt[a][1]=c;
            45        }

            46        for(int i=1;i<=n;i++)
            47            dfs(i);
            48       m=nextInt();
            49       for(int i=0;i<m;i++)
            50       {
            51           int a=nextInt(),b=nextInt();
            52          System.out.println(dp[a][b].multiply(new BigDecimal("100")).stripTrailingZeros().toPlainString()+"%");
            53       }

            54    }

            55}

            posted on 2011-02-05 20:59 yzhw 閱讀(321) 評論(0)  編輯 收藏 引用 所屬分類: DPgraph

            <2011年1月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久亚洲精品成人AV| .精品久久久麻豆国产精品| 久久综合久久鬼色| 久久精品aⅴ无码中文字字幕不卡| 成人午夜精品无码区久久| 青青青国产精品国产精品久久久久| 九九久久精品国产| 久久精品麻豆日日躁夜夜躁| AAA级久久久精品无码区| 少妇久久久久久久久久| 久久久久国产成人精品亚洲午夜| 麻豆成人久久精品二区三区免费| 国产精品xxxx国产喷水亚洲国产精品无码久久一区| 久久久久这里只有精品| 久久九九有精品国产23百花影院| 久久人人爽人人爽人人片AV不| 99久久精品久久久久久清纯| 久久99精品久久久久久久不卡| 日本加勒比久久精品| 亚洲乱亚洲乱淫久久| 91精品国产乱码久久久久久 | 久久综合九色综合久99| 成人综合伊人五月婷久久| 伊人色综合久久天天人手人婷| 久久一区二区三区99| 岛国搬运www久久| 日韩一区二区久久久久久| 91精品国产高清久久久久久io| 久久香综合精品久久伊人| 天堂久久天堂AV色综合| 午夜精品久久久久久久久| 亚洲愉拍99热成人精品热久久| 中文成人久久久久影院免费观看 | 香港aa三级久久三级| 青青青伊人色综合久久| 一本伊大人香蕉久久网手机| 久久综合九色综合久99| 国内精品久久久久国产盗摄| 性做久久久久久免费观看| 久久这里的只有是精品23| 亚洲中文久久精品无码ww16|