尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

2971:抓住那头牛

2971:抓住那头牛
📅 发布时间:2026/6/20 0:08:03

题目

总时间限制: 2000ms 内存限制: 65536kB

描述

农夫知道一头牛的位置,想要抓住它。农夫和牛都位于数轴上,农夫起始位于点N(0<=N<=100000),牛位于点K(0<=K<=100000)。农夫有两种移动方式:

1、从X移动到X-1或X+1,每次移动花费一分钟
2、从X移动到2*X,每次移动花费一分钟

假设牛没有意识到农夫的行动,站在原地不动。农夫最少要花多少时间才能抓住牛?

输入

两个整数,N和K

输出

一个整数,农夫抓到牛所要花费的最小分钟数

样例输入

5 17

样例输出

4

题意

农夫起始位置为N,牛的位置为K,输入为N和K,农夫每分钟可以向左或向右移动一步(从X到X-1或X+1),或者将当前位置翻倍(从X到2*X),每次移动花费一分钟,输出最少分钟数。

思路

用深度优先搜索+递归,从牛的位置K开始向农夫的位置N查找。如果农夫位置N大于牛位置K,通过每次后退一步的方式(花费N-K分钟);否则,从K位置开始,通过三种操作反向思考:当K为奇数时,+1或-1,当K为偶数时,/2(对应农夫的*2)

代码

#include<bits/stdc++.h>
using namespace std;
int n,k,ans;
void d(int x,int y,int sum){//递归函数,x是农夫位置,y是牛位置,sum是已花费时间if(ans<=sum) return;//如果当前时间已经超过已知最小时间,返回ans=min(ans,sum+abs(y-x));//更新最短时间为当前时间加上走到牛的位置的时间if(x==y){//如果已经到达ans=min(ans,sum);//更新时间return;}if(x>y){//如果农夫在牛右边,向左走d(x,y+1,sum+1);}else{//如果农夫在牛左边if(y%2!=0){//如果牛的位置是奇数d(x,y+1,sum+1);//牛位置+1d(x,y-1,sum+1);//牛位置-1}else{//如果牛的位置是偶数d(x,y/2,sum+1);//牛位置/2}}return;
}
int main(){cin>>n>>k;if(n>k){//如果农夫在牛右边,向左走cout<<n-k;return 0;}ans=k-n;//初始化答案为直接走到的时间d(n,k,0);//调用cout<<ans;return 0;
}

相关新闻

  • MFC Button 控件完全指南:从基础到进阶 - 指南
  • vulnhub靶机:GoldenEye-v1
  • 深入解析:SpringMVC静态资源与Servlet容器指南

最新新闻

  • 终极指南:如何使用 nunif iw3 将普通2D视频转换为沉浸式VR 3D体验
  • Display Driver Uninstaller深度清理方案:显卡驱动残留问题的终极解决方案(2024版)
  • 上海正规靠谱空调维修公司推荐,全城优选上海迪迅通制冷设备 - 星际AI
  • SPI协议深度解析:从时钟相位到错误处理,以MC68HC908GR8为例
  • 5分钟掌握2D转3D视频转换:让平面影像立体化的AI魔法
  • 嵌入式系统热设计与功耗分析:从LPC435x数据手册到可靠硬件设计

日新闻

  • 信任的进化:技术实现详解——如何用JavaScript构建博弈论模拟器
  • Terrakube自定义工作流:如何集成OPA、Infracost等工具扩展IaC能力
  • grunt-concurrent快速入门:5分钟学会并行运行Grunt任务

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号