POJ——3126Prime Path(双向BFS+素数筛打表)
Time Limit: 1000MS | Memory Limit: 65536K | |
Total Submissions: 16272 | Accepted: 9195 |
Description
— It is a matter of security to change such things every now and then, to keep the enemy in the dark.
— But look, I have chosen my number 1033 for good reasons. I am the Prime minister, you know!
— I know, so therefore your new number 8179 is also a prime. You will just have to paste four new digits over the four old ones on your office door.
— No, it’s not that simple. Suppose that I change the first digit to an 8, then the number will read 8033 which is not a prime!
— I see, being the prime minister you cannot stand having a non-prime number on your door even for a few seconds.
— Correct! So I must invent a scheme for going from 1033 to 8179 by a path of prime numbers where only one digit is changed from one prime to the next prime.
Now, the minister of finance, who had been eavesdropping, intervened.
— No unnecessary expenditure, please! I happen to know that the price of a digit is one pound.
— Hmm, in that case I need a computer program to minimize the cost. You don't know some very cheap software gurus, do you?
— In fact, I do. You see, there is this programming contest going on... Help the prime minister to find the cheapest prime path between any two given four-digit primes! The first digit must be nonzero, of course. Here is a solution in the case above.
1033
1733
3733
3739
3779
8779
8179
The cost of this solution is 6 pounds. Note that the digit 1 which got pasted over in step 2 can not be reused in the last step – a new 1 must be purchased.
Input
Output
Sample Input
3
1033 8179
1373 8017
1033 1033
Sample Output
6
7
0
单向BFS水题,但是双向让我调试了很久,因为写单向的时候是分4种情况,然后想着双向用for来放在一个循环里好了,结果样例输出答案完全不对,只有答案为1或2的时候可能会对,不解一个早上= =刚才想着算了把for去掉写麻烦点,结果又因为忘记删掉调试输出的语句,WA几发。现在还是不知道为什么原来的for是错的。双向BFS给我一个感觉:代码真长(虽然大部分是重复的)嗯这题写完之后上学期遗留的题除了一道题意本身不清楚+大部分AC代码本身也有明显错误的那道题之外全部A掉了。看看专题训练status里我刷了好几页的历史。真是个悲伤的故事……双向的时候要按层搜索
代码:
#include<iostream>
#include<algorithm>
#include<cstdlib>
#include<sstream>
#include<cstring>
#include<cstdio>
#include<string>
#include<deque>
#include<stack>
#include<cmath>
#include<queue>
#include<set>
#include<map>
using namespace std;
#define INF 0x3f3f3f3f
#define MM(x) memset(x,0,sizeof(x))
#define MMINF(x) memset(x,INF,sizeof(x))
typedef long long LL;
const double PI=acos(-1.0);
const int N=10010;
int vis[N],prime[N];
int color[N];
struct info
{
char s[6];
int step;
};
info S,T;
int change(char s[])
{
int r=0;
for (int i=0; i<4; i++)
r=r*10+s[i]-'0';
return r;
}
queue<info>Qf,Qb;
int T_bfs()
{
S.step=0;
T.step=0;
int lay=0;
while (!Qf.empty())
Qf.pop();
while (!Qb.empty())
Qb.pop();
Qf.push(S);
Qb.push(T);
color[change(S.s)]=1;
color[change(T.s)]=2;
while ((!Qf.empty())||(!Qb.empty()))
{
while(!Qf.empty()&&Qf.front().step==lay)
{
info now=Qf.front();
Qf.pop();
info v=now;
while (--v.s[0]>='1')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=1;
vis[num]=v.step;
Qf.push(v);
}
else if(color[num]==2)
{
return vis[num]+vis[change(now.s)];
}
}
} v=now;
while (++v.s[0]<='9')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=1;
vis[num]=v.step;
Qf.push(v);
}
else if(color[num]==2)
{
return vis[num]+vis[change(now.s)];
}
}
} v=now;
while (--v.s[1]>='0')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=1;
vis[num]=v.step;
Qf.push(v);
}
else if(color[num]==2)
{
return vis[num]+vis[change(now.s)];
}
}
}
v=now;
while (++v.s[1]<='9')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=1;
vis[num]=v.step;
Qf.push(v);
}
else if(color[num]==2)
{
return vis[num]+vis[change(now.s)];
}
}
} v=now;
while (--v.s[2]>='0')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=1;
vis[num]=v.step;
Qf.push(v);
}
else if(color[num]==2)
{
return vis[num]+vis[change(now.s)];
}
}
}
v=now;
while (++v.s[2]<='9')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=1;
vis[num]=v.step;
Qf.push(v);
}
else if(color[num]==2)
{
return vis[num]+vis[change(now.s)];
}
}
} v=now;
while (--v.s[3]>='0')
{
int num=change(v.s);
if(num%2==0)
continue;
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=1;
vis[num]=v.step;
Qf.push(v);
}
else if(color[num]==2)
{
return vis[num]+vis[change(now.s)];
}
}
}
v=now;
while (++v.s[3]<='9')
{
int num=change(v.s);
if(num%2==0)
continue;
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=1;
vis[num]=v.step;
Qf.push(v);
}
else if(color[num]==2)
{
return vis[num]+vis[change(now.s)];
}
}
}
}
//
while(!Qb.empty()&&Qb.front().step==lay)
{
info now=Qb.front();
Qb.pop();
info v=now;
while (--v.s[0]>='1')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=2;
vis[num]=v.step;
Qb.push(v);
}
else if(color[num]==1)
{
return vis[num]+vis[change(now.s)];
}
}
} v=now;
while (++v.s[0]<='9')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=2;
vis[num]=v.step;
Qb.push(v);
}
else if(color[num]==1)
{
return vis[num]+vis[change(now.s)];
}
}
} v=now;
while (--v.s[1]>='0')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=2;
vis[num]=v.step;
Qb.push(v);
}
else if(color[num]==1)
{
return vis[num]+vis[change(now.s)];
}
}
} v=now;
while (++v.s[1]<='9')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=2;
vis[num]=v.step;
Qb.push(v);
}
else if(color[num]==1)
{
return vis[num]+vis[change(now.s)];
}
}
}
//// v=now;
while (--v.s[2]>='0')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=2;
vis[num]=v.step;
Qb.push(v);
}
if(color[num]==1)
{
return vis[num]+vis[change(now.s)];
}
}
} v=now;
while (++v.s[2]<='9')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=2;
vis[num]=v.step;
Qb.push(v);
}
else if(color[num]==1)
{
return vis[num]+vis[change(now.s)];
}
}
} // v=now;
while (--v.s[3]>='0')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=2;
vis[num]=v.step;
Qb.push(v);
}
else if(color[num]==1)
{
return vis[num]+vis[change(now.s)];
}
}
} v=now;
while (++v.s[3]<='9')
{
int num=change(v.s);
if(prime[num])
{
if(!color[num])
{
v.step=now.step+1;
color[num]=2;
vis[num]=v.step;
Qb.push(v);
}
else if(color[num]==1)
{
return vis[num]+vis[change(now.s)];
}
}
}
}
lay++;
}
}
int main(void)
{
int tcase,i,j;
for (i=0; i<N; i++)
prime[i]=1;
for (i=2; i<N; ++i)
for (j=2; j*i<N; ++j)
prime[i*j]=0;
scanf("%d",&tcase);
while (tcase--)
{
MM(vis);
MM(color);
scanf("%s%s",S.s,T.s);
if(strcmp(S.s,T.s)==0)
puts("0");
else
printf("%d\n",T_bfs()+1);
}
return 0;
}
POJ——3126Prime Path(双向BFS+素数筛打表)的更多相关文章
- poj3126Prime Path (BFS+素数筛)
素数筛:需要一个数组进行标记 最小的素数2,所有是2的倍数的数都是合数,对合数进行标记,然后找大于2的第一个非标记的数(肯定是素数),将其倍数进行标记,如此反复,若是找n以内的所有素数,只需要对[2, ...
- poj 3048 Max Factor(素数筛)
这题就是先写个素数筛,存到prime里,之后遍历就好,取余,看是否等于0,如果等于0就更新,感觉自己说的不明白,引用下别人的话吧: 素数打表,找出20000之前的所有素数,存入prime数组,对于每个 ...
- [poj] 2549 Sumsets || 双向bfs
原题 在集合里找到a+b+c=d的最大的d. 显然枚举a,b,c不行,所以将式子移项为a+b=d-c,然后双向bfs,meet int the middle. #include<cstdio&g ...
- HDU - 4548-美素数 (欧拉素数筛+打表)
小明对数的研究比较热爱,一谈到数,脑子里就涌现出好多数的问题,今天,小明想考考你对素数的认识. 问题是这样的:一个十进制数,如果是素数,而且它的各位数字和也是素数,则称之为"美素数&quo ...
- POJ 3126 Prime Path (BFS + 素数筛)
链接 : Here! 思路 : 素数表 + BFS, 对于每个数字来说, 有四个替换位置, 每个替换位置有10种方案(对于最高位只有9种), 因此直接用 BFS 搜索目标状态即可. 搜索的空间也不大. ...
- poj 1077 Eight(双向bfs)
题目链接:http://poj.org/problem?id=1077 思路分析:题目要求在找出最短的移动路径,使得从给定的状态到达最终状态. <1>搜索算法选择:由于需要找出最短的移动路 ...
- POJ_3126 Prime Path 【BFS+素数打表】
一.题目 http://poj.org/problem?id=3126 二.分析 该题主要是要让我们找到一个$4$位素数到另一个$4$位素数的最少的变换次数,且要求保证每一次变换都满足 1.下一个数必 ...
- Uva 1599 Ideal Path - 双向BFS
题目连接和描述以后再补 这题思路很简单但还真没少折腾,前后修改提交了七八次才AC...(也说明自己有多菜了).. 注意问题: 1.看清楚原题的输入输出要求,刚了书上的中文题目直接开撸,以为输入输出都是 ...
- Codeforces_776B: Sherlock and his girlfriend(素数筛)
题目链接 题意:对2~n+1染色,一个数不能与其素因子同色. 故而只需两种颜色即可,素数染1,合数染2便可满足条件 #include<bits/stdc++.h> using namesp ...
随机推荐
- Android 检查内存溢出
工具网址:https://github.com/square/leakcanary 中文版说明地址:http://www.liaohuqiu.net/cn/posts/leak-canary-read ...
- Android程序中使用iconfont心得
1.关于iconfont iconfont既是icon又是font,具体来说应该是用font形式展现的icon.与传统图片格式的图标不同,这一种图标因为是以字体形式展现的,所以更改大小.颜色.背景颜色 ...
- 解决Unsupported major.minor version 51.0报错问题
问题产生原因:计算机环境变量的jdk版本与eclipse使用的jdk版本不一致 解决方法: 1.查看计算机环境变量的jdk版本 2.查看eclipse项目java compiler的方法:在项目点右键 ...
- LR中常见请求的使用示例
Action(){ //application/x-www-form-urlencoded //application/json //web_add_auto_header("Content ...
- 洛谷 P2419 [USACO08JAN]牛大赛Cow Contest
题目背景 [Usaco2008 Jan] 题目描述 N (1 ≤ N ≤ 100) cows, conveniently numbered 1..N, are participating in a p ...
- (二)mybaits之ORM模型
前言:为什么还没有进入到mybatis的学习呢?因为mybatis框架的核心思想就是ORM模型,所以好好了解一下ORM模型是有必要哒. ORM模型 ORM(Object Relational Ma ...
- 如何在Kubernetes里创建一个Nginx应用
使用命令行kubectl run --image=nginx nginx-app --port=80 创建一个名为nginx-app的应用 结果: deployment.apps/nginx-app ...
- 关于HTML5中Video标签无法播放mp4的解决办法
1.首先先排除掉代码问题.路径问题.浏览器不支持问题等常规问题,这些问题另行百度. <video width="500px" height="300px" ...
- Gym 100342I Travel Agency (Tarjan)
题意读懂了就好做了,就是求一下点双连通分量.维护一下一颗子树的结点数,对于一个结点当u是割点的时候, 统计一下u分割的连通分量v,每得到一个连通分量的结点数cnt(v)和之前连通分量结点数sum相乘一 ...
- Python数据结构和类型--解压序列赋值多个变量
Python数据结构和类型 1.1 解压序列赋值给多个变量 现在有一个包含N个元素的元组或者是序列,怎样将它里面的值解压后同时赋值给N个变量? 解决思路:先通过简单的解压赋值给多个变量,前提是变量的数 ...