博客
关于我
浙江农林大学第十九届程序设计竞赛暨天梯赛选拔赛 灾难预警 (二分+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/

    你可能感兴趣的文章
    Node-RED中将CSV数据写入txt文件并从文件中读取解析数据
    查看>>
    Node-RED中建立TCP服务端和客户端
    查看>>
    Node-RED中建立Websocket客户端连接
    查看>>
    Node-RED中建立静态网页和动态网页内容
    查看>>
    Node-RED中解析高德地图天气api的json数据显示天气仪表盘
    查看>>
    Node-RED中连接Mysql数据库并实现增删改查的操作
    查看>>
    Node-RED中通过node-red-ui-webcam节点实现访问摄像头并截取照片预览
    查看>>
    Node-RED中配置周期性执行、指定时间阶段执行、指定时间执行事件
    查看>>
    Node-RED安装图形化节点dashboard实现订阅mqtt主题并在仪表盘中显示温度
    查看>>
    Node-RED怎样导出导入流程为json文件
    查看>>
    Node-RED订阅MQTT主题并调试数据
    查看>>
    Node-RED通过npm安装的方式对应卸载
    查看>>
    node-request模块
    查看>>
    node-static 任意文件读取漏洞复现(CVE-2023-26111)
    查看>>
    Node.js 8 中的 util.promisify的详解
    查看>>
    node.js debug在webstrom工具
    查看>>
    Node.js HTTP模块详解:创建服务器、响应请求与客户端请求
    查看>>
    Node.js RESTful API如何使用?
    查看>>
    node.js url模块
    查看>>
    Node.js Web 模块的各种用法和常见场景
    查看>>