POJ3278 (果bfs)
2017-04-07 15:43
183 查看
RE到死。。。
看了题解才知道忘了剪枝了。。。
比较果的BFS(一开始竟然想成了dfs。。。。菜)
题意:大概是给n,k 将通过将n进行+1,-1,*2的运算求最少需要多上次可以转化为k。
#include <iostream>
#include <cstdio>
#include <string>
#include <queue>
#include <algorithm>
using namespace std;
const int maxn =1e5+10;
int vis[maxn];
int n,k;
int bfs()
{
queue<int>que;
que.push(n);
while(!que.empty())
{
int t=que.front();que.pop();
if(t==k) return vis[t]-1;
if(t-1>=0&&!vis[t-1])
{
vis[t-1]=vis[t]+1;
que.push(t-1);
}
if(t+1<maxn&&!vis[t+1])
{
vis[t+1]=vis[t]+1;
que.push(t+1);
}
if(t*2<maxn&&!vis[t*2])
{
vis[t*2]=vis[t]+1;
que.push(t*2);
}
}
}
int main()
{
scanf("%d%d",&n,&k);
vis
=1;
int ans=bfs();
printf("%d\n",ans);
}
看了题解才知道忘了剪枝了。。。
比较果的BFS(一开始竟然想成了dfs。。。。菜)
题意:大概是给n,k 将通过将n进行+1,-1,*2的运算求最少需要多上次可以转化为k。
#include <iostream>
#include <cstdio>
#include <string>
#include <queue>
#include <algorithm>
using namespace std;
const int maxn =1e5+10;
int vis[maxn];
int n,k;
int bfs()
{
queue<int>que;
que.push(n);
while(!que.empty())
{
int t=que.front();que.pop();
if(t==k) return vis[t]-1;
if(t-1>=0&&!vis[t-1])
{
vis[t-1]=vis[t]+1;
que.push(t-1);
}
if(t+1<maxn&&!vis[t+1])
{
vis[t+1]=vis[t]+1;
que.push(t+1);
}
if(t*2<maxn&&!vis[t*2])
{
vis[t*2]=vis[t]+1;
que.push(t*2);
}
}
}
int main()
{
scanf("%d%d",&n,&k);
vis
=1;
int ans=bfs();
printf("%d\n",ans);
}
相关文章推荐
- POJ3278 Catch That Cow(BFS) 坑爹的RE
- poj3278--Catch That Cow(BFS+裁剪记录)
- Poj3278 Catch That Cow (BFS)
- [POJ3278]Catch That Cow【BFS】
- POJ3278 抓奶牛 BFS
- poj3278 Catch That Cow BFS
- poj3278 BFS入门
- 空间最短路径,BFS(POJ3278)
- POJ3278 Catch That Cow(bfs)
- [bfs] poj3278 Catch that Cow
- poj3278 Catch That Cow bfs
- poj3278 BFS
- POJ3278-Catch That Cow(bfs)
- poj3278 Catch That Cow BFS搜索 TWT Tokyo Olympic 2combo-1
- POJ3278 Catch That Cow(BFS)
- POJ3278 Catch That Cow(BFS入门)
- poj3278简单BFS
- poj3278 Catch That Cow---bfs
- poj3278 bfs
- Poj3278 Catch That Cow ( BFS