noi.openjudge——2971 抓住那头牛
- http://noi.openjudge.cn/ch0205/2971/
- 总时间限制:
- 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 BFS
#include <iostream> #define maxn 100000 using namespace std; int s,t,head,tail; bool vis[maxn+]; struct node
{
int now,val;
}que[maxn+]; int main()
{
cin>>s>>t;
que[tail].now=s;
que[tail++].val=;
vis[s]=;
while(head<tail)
{
int now=que[head].now,val=que[head].val;
if(now==t)
{
cout<<val;
return ;
}
if(!vis[now*]&&now*<=maxn&&now)
{
que[tail].now=now*;
que[tail++].val=val+;
vis[now*]=;
}
if(!vis[now+]&&now+<=maxn&&now<t)
{
que[tail].now=now+;
que[tail++].val=val+;
vis[now+]=; }
if(!vis[now-]&&now>)
{
que[tail].now=now-;
que[tail++].val=val+;
vis[now-]=;
}
head++;
}
return ;
}无限ER
#include<iostream>
#include<cstdio>
#include<cstdlib> using namespace std; int n,k;
int b[]; struct sop
{
int sum;
int step;
}queue[]; void bfs(int n,int k)
{
int head=;
int tail=;
queue[tail].sum=n;
queue[tail].step=;
b[n]=;
while(head<tail)
{
head++;
if(queue[head].sum==k)
{
cout<<queue[head].step;
return;
}
if(!b[queue[head].sum*]&&(queue[head].sum*<=)&&(queue[head].sum!=))
{
tail++;
queue[tail].sum=queue[head].sum*;
b[queue[head].sum*]=;
queue[tail].step=queue[head].step+;
}
if(!b[queue[head].sum+]&&(queue[head].sum+<=)&&(queue[head].sum+<=k))
{
tail++;
queue[tail].sum=queue[head].sum+;
b[queue[head].sum+]=;
queue[tail].step=queue[head].step+;
}
if(!b[queue[head].sum-]&&(queue[head].sum->=))
{
tail++;
queue[tail].sum=queue[head].sum-;
b[queue[head].sum-]=;
queue[tail].step=queue[head].step+;
}
}
return ;
} int main()
{
cin>>n>>k; bfs(n,k);
return ;
}AC题解
noi.openjudge——2971 抓住那头牛的更多相关文章
- OpenJudge 2971 抓住那头牛
总时间限制: 2000ms 内存限制: 65536kB 描述 农夫知道一头牛的位置,想要抓住它.农夫和牛都位于数轴上,农夫起始位于点N(0<=N<=100000),牛位于点K(0< ...
- noi 2971 抓住那头牛
2971:抓住那头牛 查看 提交 统计 提问 总时间限制: 2000ms 内存限制: 65536kB 描述 农夫知道一头牛的位置,想要抓住它.农夫和牛都位于数轴上,农夫起始位于点N(0<=N ...
- OpenJudge 4001:抓住那头牛
题目链接 题解: 这个题可以用广搜来解决,从农夫到牛的走法每次都有三种选择,定义一个队列,把农夫的节点加进队列,然后以这三种走法找牛,队列先进先出,按顺序直到找到牛的位置. 代码: #include& ...
- 【bfs】抓住那头牛
[题目] 农夫知道一头牛的位置,想要抓住它.农夫和牛都位于数轴上,农夫起始位于点N(0≤N≤100000),牛位于点K(0≤K≤100000).农夫有两种移动方式: 1.从X移动到X-1或X+1,每次 ...
- [poj3278]抓住那头牛
题目描述 Farmer John has been informed of the location of a fugitive cow and wants to catch her immediat ...
- POJ-3278 抓住这头牛
广搜解决. 广搜搜出最短路,直接输出返回就行了. 每个点只搜一次,而且界限进行一次判断. else 语句里面不要用if else if,这样的话就直走一条路了. #include <ios ...
- 双向广搜 codevs 3060 抓住那头奶牛
codevs 3060 抓住那头奶牛 USACO 时间限制: 1 s 空间限制: 16000 KB 题目等级 : 黄金 Gold 题目描述 Description 农夫约翰被告知一头逃跑奶牛 ...
- BZOJ1646: [Usaco2007 Open]Catch That Cow 抓住那只牛
1646: [Usaco2007 Open]Catch That Cow 抓住那只牛 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 634 Solved ...
- 2014.6.14模拟赛【bzoj1646】[Usaco2007 Open]Catch That Cow 抓住那只牛
Description Farmer John has been informed of the location of a fugitive cow and wants to catch her i ...
随机推荐
- mac 安装 swoole 可能会出现的错误
请先看完之后再操作 一.用pecl安装swoole(没有安装起来) 2018年4月,由于homebrew的变动,导致无法使用brew install的方式安装php的扩展,现在改为用pecl安装,pe ...
- Sublime Text Version 3.0,Build3143注册码
1.打开sublime text软件2.Help->Enter License3.复制以下BEGIN LICENSE和END LICENSE之间的部分,粘贴进去.(注意:不要复制BEGIN LI ...
- 【Leetcode146】LRU Cache
问题描述: 设计一个LRU Cache . LRU cache 有两个操作函数. 1.get(key). 返回cache 中的key对应的 val 值: 2.set(key, value). 用伪代码 ...
- 简单TCP代码
服务器: SOCKET s; s = ::socket(AF_INET,SOCK_STREAM,); sockaddr_in addr; addr.sin_family = AF_INET; addr ...
- Sql Server 优化 SQL 查询:如何写出高性能SQL语句
1. 首先要搞明白什么叫执行计划? 执行计划是数据库根据SQL语句和相关表的统计信息作出的一个查询方案,这个方案是由查询优化器自动分析产生的,比如一条SQL语句如果用来从一个 10万条记录的表中查1条 ...
- JS高级——函数的调用模式
函数调用模式一共有四种 <script> //1.函数模式 //this指向window全局对象 //2.方法模式 //this指向调用这个方法的对象 //3.构造函数模式 //this ...
- 我的 Windows 10 的基本配置
Windows 10 的基本配置 功能性 开启 .Net Framework 3.5(包括 .NET 2.0 和 3.0) 旧版本 Windows 10 默认只安装了 .Net Framework 4 ...
- Operation Queues 面向对象的封装
Operation Queues An operation queue is the Cocoa equivalent of a concurrent dispatch queue and is im ...
- Python 之scrapy框架58同城招聘爬取案例
一.项目目录结构: 代码如下: # -*- coding: utf-8 -*- # Define here the models for your scraped items # # See docu ...
- ES6 作用域的问题