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

            PKU 3860 Fruit Weights 圖論 SPFA最短路變形

            Summary

            有N種水果,現(xiàn)知道許多以下的關(guān)系:

            aX<=bY

            表示:a個X水果的重量小于b個水果Y的重量。給出許多這些小于關(guān)系后,最后問a個X水果和b個Y水果的重量關(guān)系。水果的數(shù)目不超過一百。

            Solution

            這個問題可以轉(zhuǎn)化成圖論問題考慮。視每個水果為一個節(jié)點(diǎn),對于關(guān)系aX<=bY,我們可以建立一條從Y到X的邊,權(quán)值為a/b,意思是Y水果的單位重量至少是X水果的a/b倍。

            然后使用floyd算法求一次最短路,將加法改成乘法即可。算出每種水果之間的重量比例關(guān)系。

            檢查算出來的矩陣,如果有g(shù)[i][i]>1,那么就是出現(xiàn)矛盾,判為INCONSISTENT。

            如果要判定aX是否<=bY,也就是判定Y>=(a/b)X。對于算出的矩陣,g[Y][X]表示Y>=g[Y][X]X。若判定Y>=(a/b)X成立,必有(a/b)<=G[Y][X]。

            對于相等的情況特判一下即可。

             1#include <cstdio>
             2#include <cstring>
             3#include <string>
             4#include <map>
             5#include <algorithm>
             6using namespace std;
             7#define N 105
             8#define EPS 1e-8
             9double g[N][N];
            10char s1[N], s2[N];
            11int n;
            12map<stringint> MAP;
            13 
            14void solve() {
            15    int i, j, k, cnt = 0, a, b, x, y;
            16    memset(g, 0sizeof(g));
            17    MAP.clear();
            18    for (i = 0; i < n; i++{
            19        scanf("%d%s%d%s"&a, s1, &b, s2);
            20        if (MAP.find(string(s1)) == MAP.end()) MAP[string(s1)] = cnt++;
            21        if (MAP.find(string(s2)) == MAP.end()) MAP[string(s2)] = cnt++;
            22        x = MAP[string(s1)], y = MAP[string(s2)];
            23        g[y][x] = max(g[y][x], (double) a / b);
            24    }

            25 
            26    for (i = 0; i < cnt; i++)
            27        g[i][i] = 1;
            28    for (k = 0; k < cnt; k++)
            29        for (i = 0; i < cnt; i++)
            30            for (j = 0; j < cnt; j++)
            31                if (g[i][k] > 0 && g[k][j] > 0) g[i][j] = max(g[i][j], g[i][k] * g[k][j]);
            32 
            33    scanf("%d%s%d%s"&a, s1, &b, s2);
            34    x = MAP[string(s1)], y = MAP[string(s2)];
            35 
            36    for (i = 0; i < cnt; i++)
            37        if (g[i][i] > 1{
            38            puts("INCONSISTENT");
            39            return;
            40        }

            41    if (g[y][x] >= (double) a / b - EPS && g[x][y] >= (double) b / a - EPS) puts("==");
            42    else if (g[y][x] >= (double) a / b - EPS) puts("<=");
            43    else if (g[x][y] >= (double) b / a - EPS) puts(">=");
            44    else puts("UNAVAILABLE");
            45 
            46}

            47int main() {
            48    while (scanf("%d"&n) && n)
            49        solve();
            50    return 0;
            51}

            52

            posted on 2010-10-14 17:42 yzhw 閱讀(149) 評論(0)  編輯 收藏 引用 所屬分類: graph

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

            導(dǎo)航

            統(tǒng)計

            公告

            統(tǒng)計系統(tǒng)

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久久亚洲精品蜜桃臀| 久久综合五月丁香久久激情| 久久精品亚洲乱码伦伦中文| 久久久久久亚洲精品不卡| 久久免费大片| 久久久久久久亚洲Av无码| 国产2021久久精品| 久久久久久精品久久久久| 久久99精品久久久久久久不卡| 欧美亚洲另类久久综合| 久久久久久国产精品无码下载 | 日产精品久久久久久久| 久久婷婷国产麻豆91天堂| 亚洲国产成人久久综合野外| 国内精品伊人久久久久AV影院| 国产精品成人久久久久三级午夜电影 | 久久久久亚洲精品中文字幕| 久久综合给合久久狠狠狠97色| 久久亚洲欧洲国产综合| 久久国产精品99久久久久久老狼 | 99久久精品免费看国产一区二区三区| 久久精品?ⅴ无码中文字幕| 久久久久久人妻无码| 亚洲AV无码久久精品狠狠爱浪潮| 久久综合视频网| 亚洲欧美成人久久综合中文网 | 久久久这里有精品中文字幕| 狠狠色丁香婷婷久久综合不卡| 亚洲精品美女久久久久99| 久久综合视频网| 久久久久久精品免费看SSS | 国产精品99久久久久久宅男小说 | 国产69精品久久久久9999APGF | 久久播电影网| 亚洲乱码日产精品a级毛片久久| 国产999精品久久久久久| 91麻精品国产91久久久久| 国产精品青草久久久久福利99| 久久久久亚洲av无码专区| 久久99国产综合精品女同| 99久久精品午夜一区二区|