zoukankan      html  css  js  c++  java
  • 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
    ",ans);
    }
    int main() {
        while(scanf("%d",&n)&&n) {
            get_map();
            get_ans();
        }
        return 0;
    }
  • 相关阅读:
    Shader Forge学习
    Unity 编辑器扩展
    DoTween
    游戏AI之群组行为
    Unity与服务区交互数据
    NGUI制作流光效果
    NGUI组件整理总结
    Resharp使用简记
    C#使用LitJson对Json数据解析
    BehaviorDesigner学习
  • 原文地址:https://www.cnblogs.com/jusonalien/p/4113584.html
Copyright © 2011-2022 走看看