博客
关于我
POJ3278 Cath that cow【BFS】
阅读量:176 次
发布时间:2019-02-28

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

BFS算法用于解决从起点到同一位置的最短路径问题,步数最多是多少。牛的位置固定,起点即为目标点。以下是优化后的代码和详细解释:

一、题目:

告诉你和一头牛的位置,牛是不动的,问最多走几步可以抓住这头牛。走步有三种方式:向前走1步(step +1)、向后走1步(step -1)和步数乘以2(step * 2)。

二、广搜的一般步骤:

BFS算法采用队列来逐层扩展,找到最少的步骤数。初始化队列,将起点加入队列并标记访问。每次从队首取出元素,生成所有可能的下一步,检查是否合法且未被访问过,若合法则加入队列。

三、代码:

```cpp#include
#include
using namespace std;bool vis[100005];const int max_num = 100000;int main() { int N, K; scanf("%d %d", &N, &K); if (N == K) { printf("0\n"); return 0; } queue
> q; q.push({N, 0}); vis[N] = true; while (!q.empty()) { auto current = q.front(); q.pop(); int now = current.first; int step = current.second; if (now == K) { printf("%d\n", step); return 0; } if (now + 1 <= max_num && !vis[now + 1]) { if (now + 1 == K) { printf("%d\n", step + 1); return 0; } q.push({now + 1, step + 1}); vis[now + 1] = true; } if (now - 1 >= 0 && !vis[now - 1]) { if (now - 1 == K) { printf("%d\n", step + 1); return 0; } q.push({now - 1, step + 1}); vis[now - 1] = true; } if (now * 2 <= max_num && !vis[now * 2]) { if (now * 2 == K) { printf("%d\n", step + 1); return 0; } q.push({now * 2, step + 1}); vis[now * 2] = true; } } return 0;}

四、思考:

  • BFS使用队列进行广度优先搜索,逐层扩展每个可能的位置,确保找到最短路径。
  • 处理每一步时,检查三种移动方式:+1、-1和×2,确保新位置合法且未被访问过。
  • 在找到目标点时直接输出当前步数+1,避免不必要的队列操作,提高效率。
  • 特判N等于K的情况,直接返回0步,避免后续错误处理。
  • 使用vis数组记录访问状态,确保每个位置只处理一次,保证算法的正确性和效率。
  • 五、优化效果:

    通过直接判断到达目标点而不是将目标点加入队列,显著减少了处理时间和队列操作次数,提升了算法的性能和效率。

    转载地址:http://nqwn.baihongyu.com/

    你可能感兴趣的文章
    PHP代码格式化工具phpcf常见问题解决方案
    查看>>
    PHP使用3DES算法加密解密字符串
    查看>>
    PHP使用curl multi要注意的问题:每次使用curl multi同时并发多少请求合适
    查看>>
    php使用memcached扩展的一个BUG
    查看>>
    PHP内核介绍及扩展开发指南—基础知识
    查看>>
    PHP写日志fwrite和file_put_contents的区别与性能
    查看>>
    PHP函数
    查看>>
    PHP函数__autoload失效原因(与smarty有关)
    查看>>
    PHP函数操作数字和汉字互转(100以内)
    查看>>
    PHP函数方法
    查看>>
    PHP删除指定目录下的所有文件和文件夹 | 删除指定文件
    查看>>
    php判断ip黑名单程序代码
    查看>>
    php判断复选框是否被选中的方法
    查看>>
    PHP判断指定目录下是否存在文件
    查看>>
    php判断数组是否为空
    查看>>
    PHP判断数组是否有重复值、获取重复值
    查看>>
    PHP利用正则表达式实现手机号码中间4位用星号(*)替换显示
    查看>>
    PHP加密与安全的最佳实践
    查看>>
    PHP区分 企业微信浏览器 | 普通微信浏览器 | 其他浏览器
    查看>>
    php原生代码怎么连表查询,PHP tp5中使用原生sql查询代码实例
    查看>>