博客
关于我
浙江农林大学第十九届程序设计竞赛暨天梯赛选拔赛 灾难预警 (二分+bfs)
阅读量:742 次
发布时间:2019-03-21

本文共 1919 字,大约阅读时间需要 6 分钟。

为了解决农农在浙农林大学行走时不踩进水坑的问题,我们需要设计一个程序来判断他能否在给定的水位下安全地从起点 (1, 1) 到达终点 (n, n)。我们可以使用二分查找配合广度优先搜索(BFS)来高效解决这个问题。

方法思路

  • 问题分析:农农只能在不形成水坑的地方行走。水坑的形成条件是海拔高度大于当前水位。因此,我们需要找到最大的水位X,使得在X下可以从起点到达终点。
  • 二分查找:使用二分查找来确定这个最大的X值。我们通过检查每个中间值mid来确定是否能从起点到终点走过。
  • 广度优先搜索(BFS):检查当前水位是否可以让农农通过某些路径到达终点。BFS适合用来确定图中是否存在一条可行路径。
  • 解决代码

    import sysfrom collections import dequedef main():    data = list(map(int, sys.stdin.read().split()))    ptr = 0    n = data[ptr]    ptr += 1    a = []    for i in range(n):        row = data[ptr:ptr + n]        ptr += n        a.append(row)        def check(mid):        visited = [[0] * (n + 1) for _ in range(n + 1)]        q = deque()        q.append((1, 1))        visited[1][1] = 1        if a[1][1] > mid or a[n][n] > mid:            return False        if n == 1:            return True        directions = [(-1, 0), (1, 0), (0, -1), (0, 1)]        while q:            x, y = q.popleft()            for dx, dy in directions:                nx = x + dx                ny = y + dy                if 1 <= nx <= n and 1 <= ny <= n:                    if not visited[nx][ny] and a[nx][ny] <= mid:                        if nx == n and ny == n:                            return True                        visited[nx][ny] = 1                        q.append((nx, ny))        return False    low = 1    high = 100000    max_X = 0    while low <= high:        mid = (low + high) // 2        can = check(mid)        if can:            max_X = mid            low = mid + 1        else:            high = mid - 1    q_num = data[ptr]    ptr += 1    for _ in range(q_num):        x = data[ptr]        ptr += 1        if x <= max_X:            print("Wuhu")        else:            print("Hmmm")if __name__ == "__main__":    main()

    代码解释

  • 读取输入:使用sys.stdin.read来高效读取所有输入数据,并将其转换为整数列表进行处理。
  • 二分查找:确定最大的可达水位X。初始范围为1到100000,逐步调整范围遍历每个中间值mid。
  • 检查函数(BFS):对于给定的mid值,使用BFS检查是否能从起点到达终点。所有海拔高度必须不大于mid。
  • 处理查询:对于每个查询,比较当前水位和找到的最大X值,输出相应的结果。
  • 转载地址:http://hpzgz.baihongyu.com/

    你可能感兴趣的文章
    numpy 数组与矩阵的乘法理解
    查看>>
    NumPy 数组拼接方法-ChatGPT4o作答
    查看>>
    numpy 用法
    查看>>
    Numpy 科学计算库详解
    查看>>
    Numpy.fft.fft和numpy.fft.fftfreq有什么不同
    查看>>
    Numpy.ndarray对象不可调用
    查看>>
    numpy、cv2等操作图片基本操作
    查看>>
    numpy判断对应位置是否相等,all、any的使用
    查看>>
    Numpy如何使用np.umprod重写range函数中i的python
    查看>>
    numpy数组替换其中的值(如1替换为255)
    查看>>
    numpy数组索引-ChatGPT4o作答
    查看>>
    numpy绘制热力图
    查看>>
    numpy转PIL 报错TypeError: Cannot handle this data type
    查看>>
    NutzCodeInsight 2.0.7 发布,为 nutz-sqltpl 提供友好的 ide 支持
    查看>>
    NutzWk 5.1.5 发布,Java 微服务分布式开发框架
    查看>>
    NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
    查看>>
    NVelocity标签使用详解
    查看>>
    Nvidia Cudatoolkit 与 Conda Cudatoolkit
    查看>>
    NVIDIA-cuda-cudnn下载地址
    查看>>
    nvidia-htop 使用教程
    查看>>