题目传送门 http://acm.hdu.edu.cn/showproblem.php?pid=5024
题目大意就是给你一个存在障碍的地图,每次只能旋转90度仅且一次,要你求出最长的通路
其实是一道暴力的水题,哎一开始想着很SB的方法,写了大半天都没写出来,看了看别人的枚举思路后就瞬间茅塞顿开了~~,就是以每个点为转折点,算出齐八个方向转折线路的最大和,然后每个点比较就出现最大值啦><
淼题!!!
#include <iostream> #include <cstdio> using namespace std; const int maxn = 111; char mp[maxn][maxn]; int n; int zhi_x[] = {1,-1,0,0}; int zhi_y[] = {0,0,1,-1}; int xie_x[] = {1,1,-1,-1}; int xie_y[] = {-1,1,1,-1}; int get_max(int x,int y) { int MAX = 0; int b[8] = {0}; int j = -1; for(int i = 0;i < 4;++i) { b[++j] = 1; int dx = x + zhi_x[i]; int dy = y + zhi_y[i]; for(;;dx += zhi_x[i],dy+=zhi_y[i]) { if(mp[dx][dy] == '.') b[j]++; else break; } } for(int i = 0;i < 4;++i) { b[++j] = 1; int dx = x + xie_x[i]; int dy = y + xie_y[i]; for(;;dx+=xie_x[i],dy+=xie_y[i]) { if(mp[dx][dy] == '.') b[j]++; else break; } } for(int i = 0;i < 4;++i) { for(int j = 0;j < 4;++j) { if(i!=j) MAX = max(MAX,b[i]+b[j]); } } for(int i = 4;i < 8;++i) { for(int j = 4;j < 8;++j) { if(i!=j) MAX = max(MAX,b[i]+b[j]); } } return MAX - 1; } void get_map() { for(int i = 0;i <= n+1;i++) for(int j = 0;j <= n+1;j++) mp[i][j] = '#'; for(int i = 1;i <= n;++i) for(int j = 1;j <= n;++j) scanf(" %c",&mp[i][j]); } void get_ans() { int ans = 0; for(int i = 1;i <= n;++i) for(int j = 1;j <= n;++j) if(mp[i][j] == '.')ans = max(ans,get_max(i,j)); printf("%d ",ans); } int main() { while(scanf("%d",&n)&&n) { get_map(); get_ans(); } return 0; }