/**
***= =,好吧我来翻译一下,就是有2个数A,B。A可以+1,-1,*2来改变自己的值,上面三种情况都算作操作+1。求A=B所用的最少的操作数。。。。。(0<A,B<100000).
----此题来自百练poj
A:Catch That Cow
查看 提交 统计 提问
总时间限制: 2000ms 内存限制: 65536kB
描述
Farmer John has been informed of the location of a fugitive cow and wants to catch her immediately.
He starts at a point N (0 ≤ N ≤ 100,000) on a number line and the cow is at a point K (0 ≤ K ≤ 100,000)
on the same number line. Farmer John has two modes of transportation: walking and teleporting.
* Walking: FJ can move from any point X to the points X - 1 or X + 1 in a single minute
* Teleporting: FJ can move from any point X to the point 2 × X in a single minute.
If the cow, unaware of its pursuit, does not move at all, how long does it take for Farmer John to retrieve it?
输入
Line 1: Two space-separated integers: N and K
输出
Line 1: The least amount of time, in minutes, it takes for Farmer John to catch the fugitive cow.
*/
#include<iostream>
#include<queue>
#include<string.h>//memset()
using namespace std;
int getMinStepsByBFS(int n,int k){
int xSteps[100001];
memset(xSteps,0,sizeof(xSteps));//这里将所有的该范围内的数都包含,内容为0即未操作过,否则在原来的基础上+1
queue<int> points;//此队列是用来存要进行操作的点
points.push(n);
while(!points.empty()){
int x = points.front();
if(x == k){
return xSteps[k];//广度搜索搜一次就能搜到最优解,因为他是在所有操作数相同的情况下最先搜到的
}else{
points.pop();
for(int i = 0;i < 3;i++){
switch(i){
case 0 :
if(x-1>= 0 && !xSteps[x-1] && x-1!=n){
xSteps[x-1] = xSteps[x]+1;
points.push(x-1);
}
break;
case 1 :
if(x-1 <= 100000 && !xSteps[x+1] && x+1!=n){
xSteps[x+1] = xSteps[x]+1;
points.push(x+1);
}
break;
case 2 :
if(2*x <= 100000 && !xSteps[2*x] && 2*x!=n){
xSteps[2*x] = xSteps[x]+1;
points.push(2*x);
}
break;
default :
cout<<"error"<<endl;
}
}
}
}
}
int main(){
int n,k;
cin>>n>>k;
if(n>=0 && n<=100000 && k>=0 && k<= 100000){
cout<<getMinStepsByBFS(n,k)<<endl;
}
system("pause");
return 0;
}
相关推荐
面向对象程序设计课程大作业C++和QT实现的面试管理系统源码(高分项目)面向对象程序设计课程大作业C++和QT实现的面试管理系统源码(高分项目)面向对象程序设计课程大作业C++和QT实现的面试管理系统源码(高分项目...
高级语言程序设计大作业基于C++实现的图形化数字华容道小游戏源码+课程设计报告.zip下载即用。 高级语言程序设计大作业基于C++实现的图形化数字华容道小游戏源码+课程设计报告.zip下载即用。高级语言程序设计大...
c语言程序设计作业,基于原神和碧蓝航线实现的抽卡模拟器.zipc语言程序设计作业,基于原神和碧蓝航线实现的抽卡模拟器.zipc语言程序设计作业,基于原神和碧蓝航线实现的抽卡模拟器.zipc语言程序设计作业,基于原神和...
在理解了以上知识点后,对于一个2013级C++程序设计课件的第3章程序设计初步,我们可以深入掌握如何将问题分解为算法和数据结构,以及如何在C++中通过语句、选择结构、循环结构等元素编写程序。通过学习本章,学生...
《基于Web的实验报告系统设计与实现》 本系统是一个以学生在线提交实验报告和教师在线批阅实验报告为核心功能的Web应用。采用PHP作为主要开发语言,结合CSS和JavaScript技术,构建了一个交互性强、用户体验良好的...
0513《编译原理》作业要求 设计并实现TINYC语言的扫描程序; 要求: 作业内容要求:完成扫描程序的设计与实现,具体要求为: •设计并实现TINYC语言的扫描程序; •完成并提交实验报告,扫描程序的源程序,编译后的可执行...
广东工业大学网络课程设计ping程序设计和实现 1.已知参数:目的节点IP地址或主机名 2.设计要求:通过原始套接字编程,实现Ping的基本功能 2.1初始化Windows Sockets网络环境; 2.2解析命令行参数,构造目的端socket...
不论对从未接触过并行程序设计的开发人员,还是转型面向多核体系结构进行并行程序设计的开发人员来讲,《多核程序设计技术:通过软件多线程提升性能》都是一本难得的参考书。个人觉得此书比较易懂,适合刚入门的程序...
。2013年春季学期《C++程序设计》作业题目及答案.docx
《C++程序设计教程》(修订版)是钱能教授的经典著作,专注于讲解C++语言的设计思想和实际应用。这本书不仅介绍了C++的基础语法,更深入地探讨了面向对象编程的概念,包括类、对象、继承、多态等核心概念。课后习题...
java程序设计基于JDK6和NetBeans实现宋波主编课后作业答案打印版.doc
习题集内容覆盖面广,包括:Java言的基本常识、基本语法、面向对象的基本概念、数组、字符串、异常处理、文件和数据流、图形用户界面设计、小应用程序、线程、编程规范、网络程序设计、多媒体民图形学程序设计以及...
基于Java实现的摇骰子程序源码.zipJava课程作业-基于Java实现的摇骰子程序源码.zipJava课程作业-基于Java实现的摇骰子程序源码.zipJava课程作业-基于Java实现的摇骰子程序源码.zipJava课程作业-基于Java实现的摇骰子...
HNU、图书管理系统、程序设计大作业,vs实现
C语言程序设计与实例TXT电子书 1 C语言概述 1.1 C语言的发展过程 1.2 当代最优秀的程序设计语言 1.3 C语言版本 1.4 C语言的特点 1.5 面向对象的程序设计语言 1.6 C和C++ 1.7 简单的C程序介绍 ...
软件设计模式大作业 本资源为一份完整的软件设计模式大作业,涵盖了六...本资源为一份完整的软件设计模式大作业,涵盖了六种设计模式的应用,展示了蛋糕订购系统的设计和实现过程,提供了一个完整的软件设计模式示例。
1、分析典型网络聊天应用软件(如QQ、MSN等)的实现原理,模拟设计一套网络聊天应用程序,必须实现以下功能: ①按照C/S结构分别设计服务端程序和客户端程序; ②服务端通过图形用户界面实现对服务器的控制,负责...
本书为清华大学计算机汇编语言程序设计课教材,主要阐述IBM PC及其兼容机汇编语言程序程序设计的方法和技术。全书共13章:第一、二章介绍基础知识;第三、四章说明IBM PC机的指令系统及包括伪操作在内的汇编语言程序...
1.项目代码功能经验证ok,确保稳定可靠运行。欢迎下载使用!在使用过程中,如有问题或建议,请及时私信沟通,帮助解答。...基于C++设计实现的歌词轮播系统源码+详细注释+exe可执行程序(课程作业).zip
MFC.Windows程序设计(第2版)修订版 高清pdf带源码 《MFC Windows程序设计》(第2版)(修订版)不仅扩展了已被认为是权威的关于Microsoft用于Windows API的功能强大的C++类库的阐述,还新增了有关COM、OLE和ActiveX的...