USACO Section 2.4 Overfencing

Overfencing

Kolstad and Schrijvers

Farmer John went crazy and created a huge maze of fences out in a field. Happily, he left out two fence segments on the edges, and thus created two "exits" for the maze. Even more happily, the maze he created by this overfencing experience is a `perfect' maze: you can find a way out of the maze from any point inside it.

Given W (1 <= W <= 38), the width of the maze; H (1 <= H <= 100), the height of the maze; 2*H+1 lines with width 2*W+1 characters that represent the maze in a format like that shown later - then calculate the number of steps required to exit the maze from the `worst' point in the maze (the point that is `farther' from either exit even when walking optimally to the closest exit). Of course, cows walk only parallel or perpendicular to the x-y axes; they do not walk on a diagonal. Each move to a new square counts as a single unit of distance (including the move "out" of the maze.

Here's what one particular W=5, H=3 maze looks like:

+-+-+-+-+-+
|         |
+-+ +-+ + +
|     | | |
+ +-+-+ + +
| |     |
+-+ +-+-+-+

Fenceposts appear only in odd numbered rows and and odd numbered columns (as in the example). The format should be obvious and self explanatory. Each maze has exactly two blank walls on the outside for exiting.

PROGRAM NAME: maze1

INPUT FORMAT

Line 1: W and H, space separated
Lines 2 through 2*H+2: 2*W+1 characters that represent the maze

SAMPLE INPUT (file maze1.in)

5 3
    +-+-+-+-+-+
    |         |
    +-+ +-+ + +
    |     | | |
    + +-+-+ + +
    | |     |
    +-+ +-+-+-+
    

OUTPUT FORMAT

A single integer on a single output line. The integer specifies the minimal number of steps that guarantee a cow can exit the maze from any possible point inside the maze.

SAMPLE OUTPUT (file maze1.out)

9
    
The lower left-hand corner is *nine* steps from the closest exit.

Analysis

We can solve this with a standard flood fill, using a queue to implement breadth first search. It is convenient to leave the maze in its ASCII format and just look at it as a bunch of characters, with non-space characters being walls.


Code
/*
ID: braytay1
PROG: maze1
LANG: C++
*/

#include 
<stdio.h>
#include 
<stdlib.h>
#include 
<string.h>
#include 
<assert.h>
#include 
<algorithm>
#include 
<queue>
using namespace std;
queue
<int> qq;
int W,H;
char map[202][80];
int tracy[202][80][2];
int x1=-1,y1=-1,x2=-1,y2=-1;
bool isIn(int x,int y){
    
if (x<=0||x>=2*H||y<=0||y>=2*W) return false;
    
else return true;
}

void BFS(int tra){
    
int col,row,s;
    
while (!qq.empty()){
        col
=qq.front();
        qq.pop();
        row
=qq.front();
        qq.pop();
        s
=qq.front();
        qq.pop();
        
if (tracy[col][row][tra]>0continue;
        tracy[col][row][tra]
=s;
        
if (map[col-1][row]!='-'&&isIn(col-2,row)) {qq.push(col-2);qq.push(row);qq.push(s+1);}
        
if (map[col+1][row]!='-'&&isIn(col+2,row)) {qq.push(col+2);qq.push(row);qq.push(s+1);}
        
if (map[col][row-1]!='|'&&isIn(col,row-2)) {qq.push(col);qq.push(row-2);qq.push(s+1);}
        
if (map[col][row+1]!='|'&&isIn(col,row+2)) {qq.push(col);qq.push(row+2);qq.push(s+1);}
    }

}

int max(int a[202][80][2],int tra,int h,int w){
    
int maximum=-1;
    
for (int i=0;i<h;i++){
        
for (int j=0;j<w;j++){
            
if (maximum<a[i][j][tra]) maximum=a[i][j][tra];
        }

    }

    
return maximum;
}


int main(){
    
//Initialize
    FILE *fin, *fout;
    fin 
= fopen("maze1.in""r");
    fout 
= fopen("maze1.out""w");
    assert(fin 
!= NULL && fout != NULL);
    fscanf(fin,
"%d %d\n",&W,&H);
    
for (int i=0;i<=2*H;i++){
        fgets(map[i], 
sizeof(map[i]), fin);
    }

    memset(tracy,
-1,sizeof(tracy));
    
//edge search
    for (int i=0;i<=2*W;i++){
        
if (map[0][i]!='+'&&map[0][i]!='-'{
            
if (x1==-1&&y1==-1{x1=1;y1=i;}
            
else {x2=1;y2=i;}
        }

        
if (map[2*H][i]!='+'&&map[2*H][i]!='-'{
            
if (x1==-1&&y1==-1{x1=2*H-1;y1=i;}
            
else {x2=2*H-1;y2=i;}
        }

    }

    
for (int i=0;i<=2*H;i++){
        
if (map[i][0]!='+'&&map[i][0]!='|'{
            
if (x1==-1&&y1==-1{x1=i;y1=1;}
            
else {x2=i;y2=1;}
        }

        
if (map[i][2*W]!='+'&&map[i][2*W]!='|'{
            
if (x1==-1&&y1==-1{x1=i;y1=2*W-1;}
            
else {x2=i;y2=2*W-1;}
        }

    }

    qq.push(x1);qq.push(y1);qq.push(
1);
    BFS(
0);
    qq.push(x2);qq.push(y2);qq.push(
1);
    BFS(
1);
    
for (int i=0;i<=2*H;i++){
        
for (int j=0;j<=2*W;j++){
            
int a1,a2;
            a1
=tracy[i][j][0];
            a2
=tracy[i][j][1];
            tracy[i][j][
0]=(a1<a2)?a1:a2;
        }

    }

    
int res;
    res
=max(tracy,0,2*H+1,2*W+1);
    
//Output
    fprintf(fout, "%d\n", res);
    
return 0;
}

posted on 2008-08-15 16:55 幻浪天空领主 阅读(129) 评论(0)  编辑 收藏 引用 所属分类: USACO


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2008年8月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
31123456

导航

统计

常用链接

留言簿(1)

随笔档案(2)

文章分类(23)

文章档案(22)

搜索

最新评论

阅读排行榜

评论排行榜