zoukankan      html  css  js  c++  java
  • HDOJ 1253 胜利大逃亡(bfs)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1253

    思路分析:因为问题需要寻找到达终点的最短的距离(最短的步数),即在状态转换图上需要找出层次最浅的的状态(A-1, B-1, C-1),

    所以采用bfs更快能找出答案;另外,若采用dfs则比较困难,需要遍历所有的状态才能找出结果。

    代码如下

    #include <cstdio>
    #include <iostream>
    
    const int MAX_N = 60;
    struct Point
    {
        int a, b, c;
        int time;
        Point() { a = 0; b = 0; c = 0; time = 0; }
        Point(int x, int y, int z, int step_time)
        {
            a = x; b = y; c = z; time = step_time;
        }
    };
    
    int ans = 0;
    int A, B, C, game_times;
    int map[MAX_N][MAX_N][MAX_N];
    int move[6][3] =
    {{0, 0, -1}, {0, 0, 1}, {0, -1, 0}, {0, 1, 0}, {-1, 0, 0}, {1, 0, 0}};
    Point queue[1000000];
    
    int Bfs()
    {
        int head, tail;
        Point temp;
    
        head = tail = 0;
        temp.a = temp.b = temp.c = temp.time = 0;
        queue[tail++] = temp;
    
        while (head != tail)
        {
            temp = queue[head++];
            for (int i = 0; i < 6; ++i)
            {
                int next_a = temp.a + move[i][0];
                int next_b = temp.b + move[i][1];
                int next_c = temp.c + move[i][2];
    
                if (next_a < 0 || next_b < 0 || next_c < 0
                    || next_a >= A || next_b >= B || next_c >= C
                    || map[next_a][next_b][next_c] > 0 || temp.time + 1 > game_times)
                    continue;
    
                if (next_a == A - 1 && next_b == B - 1 && next_c == C - 1)
                    return temp.time + 1;
    
                Point next(next_a, next_b, next_c, temp.time + 1);
                map[next_a][next_b][next_c] = next.time;
                queue[tail++] = next;
            }
        }
        return  -1;
    }
    
    int main()
    {
        int k;
    
        scanf("%d", &k);
        while (k--)
        {
            scanf("%d %d %d %d", &A, &B, &C, &game_times);
            for (int i = 0; i < A; ++i)
            for (int j = 0; j < B; ++j)
            for (int k = 0; k < C; ++k)
                scanf("%d", &map[i][j][k]);
    
            printf("%d
    ", Bfs());
        }
        return 0;
    }
  • 相关阅读:
    字典--------输出有序的格式
    输出数据和数据下标的两种方法
    删除操作
    搭建RabbitMQ环境(windows)
    SpringBoot 2.x 集成 Redis
    Redis 安装
    Spring Boot 数据库操作
    默认日志Logback配置
    通过poi下载图片到word
    Spring IoC 与 AOP
  • 原文地址:https://www.cnblogs.com/tallisHe/p/4469888.html
Copyright © 2011-2022 走看看