首页 > 代码库 > HDU 5024

HDU 5024

题目传送门  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\n",ans);}int main() {    while(scanf("%d",&n)&&n) {        get_map();        get_ans();    }    return 0;}

HDU 5024