码迷,mamicode.com
首页 > 其他好文 > 详细

usaco Street Race

时间:2015-10-02 18:45:00      阅读:191      评论:0      收藏:0      [点我收藏+]

标签:

图一表示一次街道赛跑的跑道。可以看出有一些路口(用 0 到 N 的整数标号),和连接这些路口的箭头。路口 0 是跑道的起点,路口 N 是跑道的终点。箭头表示单行道。运动员们可以顺着街道从一个路口移动到另一个路口(只能按照箭头所指的方向)。当运动员处于路口位置时,他可以选择任意一条由这个路口引出的街道。

技术分享

图一:有 10 个路口的街道

一个良好的跑道具有如下几个特点:

  • 每一个路口都可以由起点到达。
  • 从任意一个路口都可以到达终点。
  • 终点不通往任何路口。

运动员不必经过所有的路口来完成比赛。有些路口却是选择任意一条路线都必须到达的(称为“不可避免”的)。在上面的例子中,这些路口是 0,3,6,9。对于给出的良好的跑道,你的程序要确定“不可避免”的路口的集合,不包括起点和终点。

假设比赛要分两天进行。为了达到这个目的,原来的跑道必须分为两个跑道,每天使用一个跑道。第一天,起点为路口 0,终点为一个“中间路口”;第二天,起点是那个中间路口,而终点为路口 N。对于给出的良好的跑道,你的程序要确定“中间路口”的集合。如果良好的跑道 C 可以被路口 S 分成两部分,这两部分都是良好的,并且 S 不同于起点也不同于终点,同时被分割的两个部分满足下列条件:(1)它们之间没有共同的街道(2)S 为它们唯一的公共点,并且 S 作为其中一个的终点和另外一个的起点。那么我们称 S 为“中间路口 ”。在例子中只有路口 3 是中间路口。

数据量很小,直接暴力dfs

/*
ID: modengd1
PROG: race3
LANG: C++
*/
#include <iostream>
#include <stdio.h>
#include <memory.h>
#include <vector>
using namespace std;

bool G[101][101];
int color[101];
vector<int> ans1;
vector<int> ans2;
bool dfs(int v,int m)//是否可以走到终点
{
    color[v]=1;
    if(v==m)
        return true;
    for(int i=0;i<=m;i++)
    {
        if(G[v][i]&&!color[i])
        {
            if(dfs(i,m))
                return true;
        }
    }
    return false;
}
bool dfs2(int v,int m)//是否不会遇上以前搜过的点
{
    if(color[v]==1)
        return false;
    color[v]=2;
    for(int i=0;i<=m;i++)
    {
        if(G[v][i]&&color[i]!=2&&!dfs2(i,m))
            return false;
    }
    return true;
}
int main()
{
    freopen("race3.in","r",stdin);
    freopen("race3.out","w",stdout);
    int a,b,m;
    m=0;
    memset(G,false,sizeof(G));
    for(int i=0;scanf("%d",&a)&&a!=-1;i++)
    {
        if(a==-2)
            continue;
        m=max(m,a);
        G[i][a]=true;
        for(int j=0;scanf("%d",&a)&&a!=-2;j++)
        {
            G[i][a]=true;
            m=max(m,a);
        }
    }
    for(int i=1;i<m;i++)
    {
        memset(color,0,sizeof(color));
        color[i]=1;
        if(!dfs(0,m))
        {
            ans1.push_back(i);
            color[i]=0;
            if(dfs2(i,m))
                ans2.push_back(i);
        }
    }
    cout<<ans1.size();
    for(int i=0;i<ans1.size();i++)
        cout<<‘ ‘<<ans1[i];
    cout<<endl;
    cout<<ans2.size();
    for(int i=0;i<ans2.size();i++)
        cout<<‘ ‘<<ans2[i];
    cout<<endl;
    return 0;
}

  

usaco Street Race

标签:

原文地址:http://www.cnblogs.com/modengdubai/p/4852513.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!