方老师与素数

方老师与素数

Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others)

Submit Status

方老师最近很喜欢素数,他想玩一个游戏:

现在有两个44位的素数nnmm,你一次可以改变nn的一位数字,并且改变过后的新数字必须也是个素数,并且也不能有前导00。请问使nn变为mm最少需要多少步。

例如n=1033n=1033 m=8179m=8179

那么可行的变化是:

1033

1733

3733

3739

3779

8779

8179

Input

第一行有一个整数T(T≤100)T(T≤100),代表测试数据的组数。

对于每组数据,每行有两个4位素数N,M(没有前导00

Output

对于每一组数据,如果能够得到mm,输出最少的步数,否则输出Impossible

Sample input and output

Sample Input

3

1033 8179

1373 8017

1033 1033


Sample Output

6

7

0

//bfs感觉像是有点变形吧,有点难,第一次没大理解,第二次做还是没做出来

#include<stdio.h>
#include<string.h>
#include<math.h>
#include<queue> 
using namespace std;
struct node{
int num;
int step;
};
int n,m,prime[10001],book[10001];
void pr()    
//四位数的素数
{
int i,flag,j;
memset(prime,0,sizeof(prime));
for(i=1000;i<10000;i++)
{
flag=0;
for(j=2;j<=sqrt(i);j++)
{
if(i%j==0)
{
flag=1;
break;
}
}
if(flag==0)
prime[i]=1;
}
}
int bfs()
{
int i,j,k,t[4];
memset(book,0,sizeof(book));
queue<node>Q;
struct node p,q;
p.num=n;
p.step=0;
Q.push(p);
book[n]=1;

while(!Q.empty())
{
q=Q.front();
Q.pop();

t[0]=q.num/1000;
t[1]=(q.num/100)%10;
t[2]=(q.num/10)%10;
t[3]=q.num%10;
if(q.num==m)
return q.step;
for(i=0;i<4;i++)
{
k=t[i];
for(j=0;j<=9;j++)
{
if(j!=k)
{
t[i]=j;
int f=t[0]*1000+t[1]*100+t[2]*10+t[3];
if(prime[f]==1&&book[f]==0)
{
book[f]=1; 
p.num=f;
p.step=q.step+1;
Q.push(p);
}
}
}
t[i]=k;
}
    }
    return -1;
    }
int main()
{
    int t,ans;
pr();

scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
ans=bfs();
if(ans==-1)
printf("Impossible\n");
else
printf("%d\n",ans);
}
return 0;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值