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

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

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            综合人妻久久一区二区精品| 18岁日韩内射颜射午夜久久成人 | 久久久久久极精品久久久| 青青草国产成人久久91网| 亚洲国产精品久久久久久| 久久精品国产99久久丝袜| 久久无码专区国产精品发布| 无码人妻久久久一区二区三区| 精品少妇人妻av无码久久| 久久久久亚洲av毛片大| 久久久一本精品99久久精品66| 久久综合综合久久97色| 久久国产劲爆AV内射—百度| 久久本道伊人久久| 亚洲香蕉网久久综合影视| 国产精品久久久天天影视香蕉| 99久久做夜夜爱天天做精品| 久久九九全国免费| 人妻久久久一区二区三区| 麻豆国内精品久久久久久| 久久国产色AV免费观看| 日本WV一本一道久久香蕉| 51久久夜色精品国产| 99久久久国产精品免费无卡顿| 一本一本久久a久久精品综合麻豆| 国产精品99久久精品| 久久久久久精品无码人妻| 亚洲国产成人精品女人久久久 | 久久亚洲AV永久无码精品| 99久久99久久精品免费看蜜桃| 国内精品久久久久影院薰衣草 | 国产ww久久久久久久久久| 国内精品人妻无码久久久影院| 7777精品伊人久久久大香线蕉| 精品视频久久久久| 国产精品免费久久久久久久久| 久久精品一本到99热免费| 人妻无码中文久久久久专区| 久久精品国产99国产精品亚洲| 一本色道久久综合| 久久精品国产欧美日韩99热|