#include#include#include#include#include

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

1699. Turning Turtles

系統 1811 0

http://acm.timus.ru/problem.aspx?space=1&num=1699

從一個點到另一個點正好有一條路 所以原圖是一棵樹

先求出每一對點的最近公共祖先lca

然后一遍dfs 求出每個點到它的lca的轉彎數 最后還要判定兩個點在lca處是否還要一個轉彎

代碼:

      #include<iostream>

#include<cstdio>

#include<cstring>

#include<string>

#include<map>

#include<vector>

#include<stack>

#include<set>

#include<map>

#include<queue>

#include<deque>

#include<algorithm>

#include<cmath>

#define LL long long

#pragma comment(linker, "/STACK:1024000000,1024000000")

using namespace std;

const int INF=0x3f3f3f3f;

const int N=100005;

int head[N],I;

struct node

{

    int j,next;

    int k;

}edge[N*10];

int X[]={0,0,-1,1};

int Y[]={-1,1,0,0};

int K[]={1,1,2,2};

char grap[N];

bool visited[N];

int q1[N],q2[N],lca[N],d[N],prek[N],tok[N],k1[N],k2[N],ans[N];

int f[N];

vector<int>vt[N];

queue<int>qt;

int n,m;

void add(int i,int j,int k)

{

    edge[I].j=j;

    edge[I].k=k;

    edge[I].next=head[i];

    head[i]=I++;

}

void bfs(int s)

{

    memset(visited,false,sizeof(visited));

    visited[s]=true;

    qt.push(s);

    while(!qt.empty())

    {

        int x=qt.front();

        qt.pop();

        for(int i=0;i<4;++i)

        {

            int l1=x/m+X[i];

            int l2=x%m+Y[i];

            int st=x,nd=l1*m+l2;

            while(l1>=0&&l1<n&&l2>=0&&l2<m&&grap[nd]=='#'&&!visited[nd])

            {

                visited[nd]=true;

                qt.push(nd);

                add(st,nd,K[i]);

                st=nd;

                l1=l1+X[i];

                l2=l2+Y[i];

                nd=l1*m+l2;

            }

        }

    }

}

int fx(int x)

{

    if(f[x]!=x)

    f[x]=fx(f[x]);

    return f[x];

}

void findLca(int x)

{

    for(unsigned int i=0;i<vt[x].size();++i)

    {

        int l=vt[x][i];

        if(q1[l]==x)

        {

            if(f[q2[l]]!=-1)

            lca[l]=fx(q2[l]);

        }else

        {

            if(f[q1[l]]!=-1)

            lca[l]=fx(q1[l]);

        }

    }

}

void dfsLca(int x,int pre)

{

    f[x]=x;

    findLca(x);

    for(int t=head[x];t!=-1;t=edge[t].next)

    {

        int j=edge[t].j;

        dfsLca(j,x);

    }

    f[x]=pre;

}

void F(int x)

{

    for(unsigned int i=0;i<vt[x].size();++i)

    {

        int l=vt[x][i];

        int y=lca[l];

        if(x==q1[l])

        k1[l]=tok[y];

        else

        k2[l]=tok[y];

        ans[l]+=(d[x]-d[y]);

        if((prek[y]&tok[y])==0)

        --ans[l];

    }

}

void dfs(int x,int dt,int kt)

{

    d[x]=dt;

    prek[x]=kt;

    tok[x]=3;

    F(x);

    for(int t=head[x];t!=-1;t=edge[t].next)

    {

        int j=edge[t].j;

        tok[x]=edge[t].k;

        if((prek[x]&tok[x])==0)

        dfs(j,dt+1,edge[t].k);

        else

        dfs(j,dt,edge[t].k);

    }

}

int main()

{

    //freopen("data.in","r",stdin);

    cin>>n>>m;

    int s=-1;

    for(int i=0;i<n;++i)

    for(int j=0;j<m;++j)

    {

        cin>>grap[i*m+j];

        if(s==-1&&grap[i*m+j]=='#')

        s=i*m+j;

    }

    memset(head,-1,sizeof(head));

    I=0;

    bfs(s);

    int q;

    cin>>q;

    for(int i=0;i<q;++i)

    {

        int x1,y1,x2,y2;

        cin>>x1>>y1>>x2>>y2;

        --x1;--y1;--x2;--y2;

        q1[i]=x1*m+y1;

        q2[i]=x2*m+y2;

        if(q1[i]!=q2[i])

        vt[q1[i]].push_back(i);

        vt[q2[i]].push_back(i);

    }

    memset(f,-1,sizeof(f));

    dfsLca(s,s);

    for(int i=0;i<n*m;++i)

    vt[i].clear();

    for(int i=0;i<q;++i)

    if(q1[i]!=q2[i])

    {vt[q1[i]].push_back(i);vt[q2[i]].push_back(i);}

    memset(ans,0,sizeof(ans));

    dfs(s,0,3);

    for(int i=0;i<q;++i)

    {

        if(q1[i]==q2[i])

        {cout<<"0"<<endl;continue;}

        if((k1[i]&k2[i])==0)

        ++ans[i];

        cout<<ans[i]<<endl;

    }

    return 0;

}


    

1699. Turning Turtles


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 欧美日韩国产精品自在自线 | 欧美日韩中文在线观看 | 天天爽夜夜爽夜夜爽精品视频 | 欧美三级短视频 | 色综合中文字幕天天在线 | 亚洲精品久久久久无码AV片软件 | 国产精品入口麻豆 | 欧美在线播放一区 | 午夜在线视频 | 久久久91 | 免费高清欧美一区二区视频 | 亚洲欧美成人综合在线 | 综合一区二区三区 | 国产成人精品在线观看 | 九九精品激情在线视频 | 久久一精品 | 欧美激情高清 | 一级做a | 羞羞色院91蜜桃在线观看 | 人人插人人澡 | 欧美成人一级 | 国产人成久久久精品 | 欧美成人久久久 | 在线黄色毛片 | 99热欧美 | 日日做日日摸夜夜爽 | 亚洲在线观看 | 欧美成人手机视频 | 亚洲乱码在线卡一卡二卡新区 | 国产精品久久久久久久久久免费看 | 啪啪激情婷婷久久婷婷色五月 | av在线一区二区三区 | 噜噜噜噜狠狠狠7777视频 | 欧美三极 | 夜夜狠狠操| 久久久久久久久日本理论电影 | 亚洲欧洲视频 | 国产毛片视频 | 亚洲第一黄色网址 | 中文字幕一区二区三区四区五区 | 97视频久久久|