POJ2375 Cow Ski Area (添最少边构造强连通分量的某个与入度出度相关的结论)

题意:本题描述了一片滑雪场,并且规定奶牛从一个点只能向它相邻的并且高度不大于它的点运动,现在想要在某些点对之间加上缆车使得奶牛也可以从较低点到达较高点,问最少需要多少辆这样的缆车就可以使得奶牛可以从任意一个点运动到滑雪场的每个角落。

思路:即问至少加多少条边使图变成强联通图,先缩点成DAG。

不难知道强连通分量的所有节点的入度和出度均不为0,可以统计DAG上的入度和出度为0的个数分别是a,b。然后答案即为max(a,b)。

只是发现入度为0和出度为0的点可以按某种方式相连接总能构造出一个强连通分量,然后多余的abs(a-b)个节点也总能可某些点构成强连通分量,但是没有准确的证明orz

//9908K	266MS
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
using namespace std;
int mapp[555][555];
int c,r;
int gro[555][555];
bool indeg[250100];
bool outdeg[250100];
int col;
int nxt[4][2]={0,1,0,-1,-1,0,1,0};
void getgro(int x,int y)
{
    gro[x][y]=col;
    for(int i=-1;i<=1;i++)
        for(int j=-1;j<=1;j++)
        {
            if(j==0&&i==0) continue;
            if(j&&i) continue;
            if(gro[x+i][y+j]) continue;
            if(mapp[x+i][y+j]==mapp[x][y]) getgro(x+i,y+j);
        }
}
void ini()
{
    memset(mapp,-1,sizeof(mapp));
    memset(gro,0,sizeof(gro));
    col=0;
    memset(indeg,0,sizeof(indeg));
    memset(outdeg,0,sizeof(outdeg));
}
int main()
{
    while(~scanf("%d%d",&c,&r))
    {

        ini();
        for(int i=1;i<=r;i++)
            for(int j=1;j<=c;j++) scanf("%d",&mapp[i][j]);

        for(int i=1;i<=r;i++)
            for(int j=1;j<=c;j++)
                if(gro[i][j]==0) col++,getgro(i,j);

        for(int i=1;i<=r;i++)
            for(int j=1;j<=c;j++)
                for(int k=0;k<4;k++)
                {
                    int nx=i+nxt[k][0],ny=j+nxt[k][1];
                    if(nx<1||nx>r||ny<1||ny>c) continue;
                    if(gro[i][j]==gro[nx][ny]) continue;
                    if(mapp[i][j]>mapp[nx][ny]) indeg[gro[nx][ny]]=1,outdeg[gro[i][j]]=1;
                    else indeg[gro[i][j]] = 1,outdeg[gro[nx][ny]] = 1;
                }

        int cnta=0,cntb=0;
        for(int i=1;i<=col;i++)
        {
            if(indeg[i]==0) cnta++;
            if(outdeg[i]==0) cntb++;
        }
        if(col!=1) printf("%d\n",max(cnta,cntb));
        else puts("0");

    }
    return 0;
}

时间: 2024-12-18 12:27:02

POJ2375 Cow Ski Area (添最少边构造强连通分量的某个与入度出度相关的结论)的相关文章

POJ2375 Cow Ski Area【Tarjan】【强连通分量】

题目链接: http://poj.org/problem?id=2375 题目大意: 有一片供奶牛滑雪的滑雪场,可供滑雪的区域是W(宽)*L(长)的矩阵.上边有W*L个点.规定 奶牛从一个点只能向它上.下.左.右相邻的并且高度不大于它的点运动.现在想要在某些 点对之间架设缆车,使得奶牛可以从较低的地方想较高的地方运动,那么问题来了:最少需 要多少辆这样的缆车就可以使奶牛从每个点运动到可供滑雪区域的每个角落. 思路: 把奶牛符合从点u移动到点v的条件当做一条单向边.那么所有点和边就可以构成有向图.

POJ2375 Cow Ski Area 【强连通分量】+【DFS】

Cow Ski Area Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 2323   Accepted: 660 Description Farmer John's cousin, Farmer Ron, who lives in the mountains of Colorado, has recently taught his cows to ski. Unfortunately, his cows are some

POJ2375 Cow Ski Area (强连通)(缩点)

Cow Ski Area Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 3323   Accepted: 919 Description Farmer John's cousin, Farmer Ron, who lives in the mountains of Colorado, has recently taught his cows to ski. Unfortunately, his cows are some

POJ 2375 Cow Ski Area(强连通)

POJ 2375 Cow Ski Area 题目链接 题意:给定一个滑雪场,每个点能向周围4个点高度小于等于这个点的点滑,现在要建电缆,使得任意两点都有路径互相可达,问最少需要几条电缆 思路:强连通缩点,每个点就是一个点,能走的建边,缩点后找入度出度为0的个数的最大值就是答案,注意一开始就强连通了答案应该是0 代码: #include <cstdio> #include <cstring> #include <stack> #include <algorithm&

D - Cow Ski Area

Description Farmer John's cousin, Farmer Ron, who lives in the mountains of Colorado, has recently taught his cows to ski. Unfortunately, his cows are somewhat timid and are afraid to ski among crowds of people at the local resorts, so FR has decided

POJ 3352 Road Construction(添最少边构造边双连通图的结论)

题意:已知无向图,问添加最少的边使之成为边双连通图 思路:显然先缩点成一棵树,添加最少边使一棵树的边双连通 此处有结论:对于一棵树添加(1+leaf)>>1 条无向边就能构造成一个双连通图,构造方法显然(脑补一下 //216K 63MS C++ 1754B #include<cstdio> #include<iostream> #include<cstring> #include<algorithm> using namespace std; c

POJ 2375 Cow Ski Area (强连通分量)

题目地址:POJ 2375 对每一个点向与之相邻并h小于该点的点加有向边. 然后强连通缩点.问题就转化成了最少加几条边使得图为强连通图,取入度为0和出度为0的点数的较大者就可以.注意,当强连通分量仅仅有一个的时候.答案是0,而不是1. 代码例如以下: #include <iostream> #include <string.h> #include <math.h> #include <queue> #include <algorithm> #in

POJ 2375 Cow Ski Area【tarjan】

题目大意:一个W*L的山,每个山有个高度,当且仅当一个山不比它相邻(有公共边的格子)的山矮时能够滑过去,现在可以装化学电梯来无视山的高度滑雪,问最少装多少电梯使得任意两点都可到达 思路:最后一句话已经把强连通模型裸裸地说出来了 那问题变成了一个图最小加几条边变成强连通图的经典问题,比较一下出度为0和入度为0的点的个数的大小即可,还有个特例只有一个SCC的情况 #include<cstdio> #include<string.h> #include<iostream> #

HDU 4946 Area of Mushroom(构造凸包)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4946 题目大意:在一个平面上有n个点p1,p2,p3,p4....pn,每个点可以以v的速度在平面上移动,对于平面上任意一点,假设有唯一一个点pi从初始的位置到这个点的时间最短,那么就说平面上的这个点是属于pi这点管辖的.现在要你判断pi管辖的范围是不是无穷大的,如果是输出1,否则输出0: 首先大致的方法就是构造凸包,不过要遵循一下前提: 一定是只考虑速度最大的点,然后,如果两个点所在的位置与速度都