USACO2.4.2 Overfencing

思路:起初,计算我想的是从每个空格走到每个出口的步数,然后找出每个出口步数最多的,在从两个步数最多的里面找出走的步数少的那个。可是后来看别人的思路,其实不必这么麻烦的,只要从出口往里走就好了,走到每个空格时都会一个步数,但因为在搜索的过程中会有回溯,所以每个空格记录的应该是到达此空格时的最小步数。然后输出最大步数就好了。其实,就是floodfill算法的变形。

源代码:

/*
ID: supersnow0622
PROG: test
LANG: C++
*/
#include <iostream>
#include <fstream>
#include <string>
#include<memory.h>
using namespace std;
char ch;
int map1[300][100];
int record[300][100];
int dir[4][2]={{-1,0},{0,-1},{0,1},{1,0}};
int row,col;
int countNum=0;
int ok=0;
void DFS(int i,int j,int step)
{
  int newr,newc;
  record[i][j]=step;
  for(int a=0;a<4;a++)
  {
    newr=i+dir[a][0];
    newc=j+dir[a][1];
    if(i>=0&&j>=0&&newr<=row&&newc<=col&&map1[newr][newc]==0&&step+1<record[newr][newc])
      DFS(newr,newc,step+1);
  }
}
int main() {
    ofstream fout ("test.out");
    ifstream fin ("test.in");
    int W,H;
    int start[2][2],num=0;
    cin>>W>>H;
    row=2*H+1;col=2*W+1;
    string str;
    getline(cin,str);
    memset(map1,0,sizeof(map1));
    for(int i=0;i<row;i++)
    {
         getline(cin,str);
       for(int j=0;j<str.length();j++)
         if(str[j]!=' ')
           map1[i][j]=1;
    }
    for(int i=0;i<row;i++)
        for(int j=0;j<col;j++)
         if((i==0||j==0||i==row-1||j==col-1)&&map1[i][j]==0)
          {
           start[num][0]=i;start[num++][1]=j;
          }
      for(int i=0;i<row;i++)
        for(int j=0;j<col;j++)
         record[i][j]=100000;
      DFS(start[0][0],start[0][1],1);
      DFS(start[1][0],start[1][1],1);
      int max=0;
        for(int i=0;i<row;i++)
         {
          for(int j=0;j<col;j++)
           if(record[i][j]!=100000&&max<record[i][j])
             max=record[i][j];
         }
         cout<<max/2;
    return 0;
}


你可能感兴趣的:(USACO2.4.2 Overfencing)