青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

poj 1984 Navigation Nightmare 并查集

   并查集應(yīng)用的變形。題目意思是一個(gè)圖中,只有上下左右四個(gè)方向的邊。給出這樣的一些邊,
求任意指定的2個(gè)節(jié)點(diǎn)之間的距離。
   有可能當(dāng)前給出的信息,沒(méi)有涉及到要求的2個(gè)節(jié)點(diǎn),或者只涉及到了1個(gè)節(jié)點(diǎn),那么肯定
無(wú)法確定它們的距離。或者根據(jù)已經(jīng)給出的邊只知道這2個(gè)節(jié)點(diǎn)在不同的聯(lián)通分量里面,那么其
距離也是無(wú)法確定的,根據(jù)題目要求,輸出-1。
   問(wèn)題是如果能夠確定它們?cè)谝粋€(gè)聯(lián)通分量里面,如何確定它們的距離了。
   這個(gè)題的關(guān)鍵在于,只有上下左右四個(gè)方向的邊,假設(shè)每個(gè)節(jié)點(diǎn)都有一個(gè)坐標(biāo)的話,那么它們
相對(duì)于代表該聯(lián)通分量節(jié)點(diǎn)的坐標(biāo)肯定是固定的,那么就不需要考慮圖里面有環(huán)之類的情況了。
這樣就可以很方便的應(yīng)用并查集來(lái)解了。
   利用并查集,給每個(gè)節(jié)點(diǎn)附加其它信息,即相對(duì)于代表該并查集的節(jié)點(diǎn)的坐標(biāo)(x,y)。
在FindSet里面求出坐標(biāo),在UnionSet里面修改合并后新加入的另外一個(gè)集合的根節(jié)點(diǎn)的坐標(biāo)即可。
   代碼如下:

#include <stdio.h> 
#include <string.h>
#include <stdlib.h>
#include <algorithm>
using namespace std;

const int MAX_N = 40010;
int nN, nM;
int nSets[MAX_N];
int nX[MAX_N];
int nY[MAX_N];
char szInput[MAX_N][100];

void MakeSets(int nNum)
{
    for (int i = 0; i < nNum; ++i)
    {
        nSets[i] = i;
        nX[i] = nY[i] = 0;
    }
}

int FindSets(int nI)
{
    if (nSets[nI] != nI)
    {
        int nPre = nSets[nI];
        nSets[nI] = FindSets(nSets[nI]);
        nX[nI] += nX[nPre];
        nY[nI] += nY[nPre];
    }
    return nSets[nI];
}

void UnionSets(int nBeg, int nEnd, int dx, int dy)
{
    int nA = FindSets(nBeg);
    int nB = FindSets(nEnd);
    if (nA != nB)
    {
        nSets[nB] = nA;//把集合B合并到集合A中
        nX[nB] = nX[nBeg] + dx - nX[nEnd];//因?yàn)榉较蚰孢^(guò)來(lái)了,所以是減去
        nY[nB] = nY[nBeg] + dy - nY[nEnd];
    }
}

int main()
{
    int nBeg, nEnd, nL;
    char szDir[10];

    while (scanf("%d%d%*c", &nN, &nM) == 2)
    {
        MakeSets(nN);
        for (int i = 0; i < nM; ++i)
        {
            fgets(szInput[i], 100, stdin);
        }
        int nK;
        int nF1, nF2, nI;
        scanf("%d", &nK);
        int nCur = 0;
        while (nK--)
        {
            scanf("%d%d%d", &nF1, &nF2, &nI);
            for (int i = nCur; i < nI; ++i)
            {
                sscanf(szInput[i], "%d%d%d%s", &nBeg,
                       &nEnd, &nL, szDir);
                int dx = 0, dy = 0;
                switch (szDir[0])
                {
                    case 'N': dy += nL; break;
                    case 'S': dy -= nL; break;
                    case 'E': dx += nL; break;
                    case 'W': dx -= nL; break;
                }
                UnionSets(nBeg, nEnd, dx, dy);
            }
            nCur = nI;
            
            if (FindSets(nF1) != FindSets(nF2))
            {
                printf("-1\n");
            }
            else
            {
                printf("%d\n", abs(nX[nF1] - nX[nF2])
                        + abs(nY[nF1] - nY[nF2]));
            }
        }
    }

    return 0;
}

posted on 2012-10-09 21:25 yx 閱讀(966) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)

<2012年9月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

導(dǎo)航

統(tǒng)計(jì)

公告

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

me

好友

同學(xué)

網(wǎng)友

搜索

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产影院| 欧美国产视频在线| 久久精品女人天堂| 国产精品久久久久久久久果冻传媒 | 欧美一区二区网站| 国产精品日本一区二区| 一区二区三区欧美视频| 一本综合精品| 亚洲免费伊人电影在线观看av| 在线亚洲精品福利网址导航| 久久人人爽人人爽爽久久| 国产精品毛片一区二区三区| 99在线热播精品免费| 欧美国产日韩一区二区在线观看| 欧美一区国产一区| 国产欧美va欧美不卡在线| 午夜精品久久99蜜桃的功能介绍| av成人激情| 国产精品va在线播放我和闺蜜| 亚洲视频欧美视频| 亚洲影院在线观看| 国产亚洲欧洲一区高清在线观看 | 亚洲欧洲精品一区二区三区 | 一区二区三区国产在线| 欧美日本一道本| 一本色道久久综合亚洲精品按摩 | 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲精品中文字幕女同| 欧美日韩一区二| 欧美在线影院在线视频| 久久www成人_看片免费不卡| 国产日韩欧美| 蜜臀久久久99精品久久久久久| 久久久精品性| 日韩亚洲在线| 亚洲一本大道在线| 1000部精品久久久久久久久| 亚洲人成网站影音先锋播放| 欧美午夜不卡在线观看免费| 性做久久久久久| 久久噜噜亚洲综合| 一本色道久久88综合日韩精品| 亚洲小视频在线| 亚洲国产精品t66y| 一区二区三区视频在线| 伊人久久久大香线蕉综合直播 | 欧美日韩综合视频网址| 欧美一级视频一区二区| 美国十次成人| 亚洲欧美清纯在线制服| 久久久一区二区三区| 中文国产亚洲喷潮| 欧美一区二区三区在线免费观看 | 夜夜嗨av一区二区三区四季av| 亚洲一级黄色av| 一区二区三区精品在线| 久久嫩草精品久久久久| 日韩视频在线观看免费| 亚洲欧美日韩精品久久亚洲区| 1000部精品久久久久久久久| 一区二区激情小说| 在线不卡欧美| av成人激情| 亚洲区欧美区| 欧美一区国产在线| 亚洲欧美清纯在线制服| 免费视频最近日韩| 欧美一级播放| 欧美国产视频在线| 美女黄色成人网| 国产女人精品视频| 99精品视频一区| 亚洲精品无人区| 久久亚洲精品网站| 久久国产主播精品| 国产精品久久久久久久久久妞妞| 亚洲国产va精品久久久不卡综合| 国产综合色产在线精品| 在线午夜精品| 中日韩视频在线观看| 欧美大胆成人| 亚洲国产精品v| 亚洲电影免费在线| 欧美一区二区三区在线播放| 欧美综合国产精品久久丁香| 欧美午夜一区| 9色精品在线| 亚洲视频中文字幕| 国产精品美女久久久久久久| 一本色道精品久久一区二区三区 | 黄色日韩网站视频| 亚洲欧美美女| 欧美一级精品大片| 国产欧美一区二区精品婷婷 | 欧美大尺度在线| 欧美激情一区二区三区| 亚洲国产综合视频在线观看| 欧美成人乱码一区二区三区| 欧美激情一二区| 亚洲六月丁香色婷婷综合久久| 免费在线亚洲欧美| 亚洲国产精品久久久久秋霞不卡| 最新国产拍偷乱拍精品| 欧美大色视频| 亚洲最新合集| 久久xxxx精品视频| 狠狠色噜噜狠狠狠狠色吗综合| 久久精品国产99精品国产亚洲性色 | 一区二区三区在线观看国产| 久久丁香综合五月国产三级网站| 久久夜色精品国产噜噜av| 精品福利电影| 欧美成人蜜桃| 在线综合+亚洲+欧美中文字幕| 欧美一区二区三区啪啪| 久久精品国产欧美亚洲人人爽| 国产精品红桃| 一区二区欧美国产| 香港久久久电影| 在线精品观看| 欧美日韩视频一区二区| 亚洲——在线| 欧美激情第三页| 亚洲欧美日韩中文视频| 狠狠v欧美v日韩v亚洲ⅴ| 欧美大成色www永久网站婷| 日韩午夜电影| 久久综合色婷婷| 99成人在线| 国产亚洲成精品久久| 男女精品网站| 亚洲一二区在线| 欧美激情第9页| 欧美在线高清视频| 亚洲精品国产精品国自产观看浪潮| 欧美日韩久久精品| 久久国产福利| 亚洲无线视频| 激情欧美一区| 国产精品白丝黑袜喷水久久久| 久久精品理论片| 一区二区高清| 欧美不卡在线视频| 先锋影音国产一区| 一本色道久久88综合亚洲精品ⅰ | 亚洲视频综合在线| 欧美第一黄网免费网站| 午夜视频久久久| 一本色道综合亚洲| 在线播放国产一区中文字幕剧情欧美 | 久久精品国产精品亚洲精品| 亚洲精品在线视频| 免费在线观看成人av| 久久精品国产一区二区电影 | 久久综合网色—综合色88| 亚洲主播在线播放| 亚洲精品久久久久| 激情文学一区| 国产欧美一区二区三区国产幕精品| 女同一区二区| 久久久久国产精品一区| 亚洲天堂第二页| 日韩亚洲欧美成人| 最近看过的日韩成人| 免费的成人av| 久久中文字幕一区| 久久久噜噜噜久久| 久久精品青青大伊人av| 欧美一区二区三区四区在线观看| 亚洲图片在区色| 亚洲深夜福利视频| 亚洲视频在线观看视频| 一本色道久久综合亚洲91| 亚洲精品一区二区网址| 亚洲激情av| 亚洲精品黄色| 一级日韩一区在线观看| 日韩午夜剧场| 99精品视频一区二区三区| 猛男gaygay欧美视频| 久久人人97超碰精品888| 亚洲欧美日产图| 亚洲综合色网站| 亚洲欧美自拍偷拍| 性欧美精品高清| 久久av老司机精品网站导航| 性色av香蕉一区二区| 久久大综合网| 久久久91精品国产一区二区三区 | 亚洲男人的天堂在线aⅴ视频| 亚洲午夜黄色| 欧美中文字幕在线播放| 久久精品国产清自在天天线| 久久国产日本精品| 葵司免费一区二区三区四区五区| 毛片一区二区三区| 欧美色中文字幕| 国产欧美韩日| 亚洲国产成人porn| 9久草视频在线视频精品|