被坑了3个小时,本来以为算法错了,谁知道,竟然是素数筛弄错了

!!!

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <math.h>
using namespace std;
int a[10001];
int v[10001];
int n,m;
struct node
{
int ans,x;
}q[100001];
void bfs()
{
memset(v,0,sizeof(v));
struct node t,f;
int e=0;
int s=0;
t.ans=0;
t.x=n;
v[t.x]=1;
q[e++]=t;
while(s<e)
{
t=q[s++];
if(t.x==m)
{
printf("%d\n",t.ans);
break;
}
for(int i=0;i<=9;i++)
{
if(v[(t.x/10)*10+i]==0&&a[(t.x/10)*10+i]==1)
{
f.x=(t.x/10)*10+i;
f.ans=t.ans+1;
q[e++]=f;
v[(t.x/10)*10+i]=1;
}
if(v[(t.x/100)*100+t.x%10+i*10]==0&&a[(t.x/100)*100+t.x%10+i*10]==1)
{
f.x=(t.x/100)*100+t.x%10+i*10;
f.ans=t.ans+1;
q[e++]=f;
v[(t.x/100)*100+t.x%10+i*10]=1;
}
if(v[(t.x/1000)*1000+(t.x/10)%10*10+t.x%10+i*100]==0&&a[(t.x/1000)*1000+(t.x/10)%10*10+t.x%10+i*100]==1)
{
f.x=(t.x/1000)*1000+(t.x/10)%10*10+t.x%10+i*100;
f.ans=t.ans+1;
q[e++]=f;
v[(t.x/1000)*1000+(t.x/10)%10*10+t.x%10+i*100]=1;
}
}
for(int i=1;i<=9;i++)
{
if(v[t.x%10+(t.x/10)%10*10+(t.x/10/10)%10*100+i*1000]==0&&a[t.x%10+(t.x/10)%10*10+(t.x/10/10)%10*100+i*1000]==1)
{
f.x=t.x%10+(t.x/10)%10*10+(t.x/10/10)%10*100+i*1000;
f.ans=t.ans+1;
q[e++]=f;
v[t.x%10+(t.x/10)%10*10+(t.x/10/10)%10*100+i*1000]=1;
}
}
}
}
int main()
{
a[0]=0;
a[1]=0;
a[2]=1;
int t=(int )sqrt(10000*1.0);
for(int i=3;i<10000;i++)
{
if(i%2==0)
a[i]=0;
else a[i]=1;
}
for(int i=3;i<=t;i++)
{
if(a[i]==1)
{
for(int j=2*i;j<10000;j=j+i)
a[j]=0;
}
}
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
bfs();
}
return 0;
}

poj3126的更多相关文章

  1. POJ3126 Prime Path (bfs+素数判断)

    POJ3126 Prime Path 一开始想通过终点值双向查找,从最高位开始依次递减或递增,每次找到最接近终点值的素数,后来发现这样找,即使找到,也可能不是最短路径, 而且代码实现起来特别麻烦,后来 ...

  2. 《挑战程序设计竞赛》2.6 数学问题-素数 AOJ0009 POJ3126 3421 3292 3641

    AOJ0009 http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=0009 题意 求不大于n的素数个数. 思路 素数筛法可解,筛法过程中 ...

  3. POJ-3126 Prime Path---BFS+素数打表

    题目链接: https://vjudge.net/problem/POJ-3126 题目大意: 给两个四位数a,b 每次改变a中的一位而且改动之后的必须是素数,问最少改动几次可以到b?(永远达不到b就 ...

  4. poj3126 筛素数+bfs

    //Accepted 212 KB 16 ms //筛素数+bfs #include <cstdio> #include <cstring> #include <iost ...

  5. POJ3126 Prime Path

    http://poj.org/problem?id=3126 题目大意:给两个数四位数m, n, m的位数各个位改变一位0 —— 9使得改变后的数为素数, 问经过多少次变化使其等于n 如: 10331 ...

  6. POJ3126 Prime Path(BFS)

    题目链接. AC代码如下: #include <iostream> #include <cstdio> #include <cstring> #include &l ...

  7. poj3126(bfs)

    题目链接:http://poj.org/problem?id=3126 题意:给两个四位数n,m,将n变成m需要多少步,要求每次只能改变n的某一位数,即改变后的数与改变前的数只有一位不同,且每次改变后 ...

  8. poj3126解题报告

    题意:简单的说就是:有一个人门牌号是一个四位数的整数,并且还是一个素数,现在他想要换成另外一个四位数且是素数的门牌号,而且,每次都只能更换这个四位数的一个位置的数 ,也就是每换一次都只改变一个数字,而 ...

  9. poj3126 Prime Path 广搜bfs

    题目: The ministers of the cabinet were quite upset by the message from the Chief of Security stating ...

  10. Prime Path[POJ3126] [SPFA/BFS]

    描述 孤单的zydsg又一次孤单的度过了520,不过下一次不会再这样了.zydsg要做些改变,他想去和素数小姐姐约会. 所有的路口都被标号为了一个4位素数,zydsg现在的位置和素数小姐姐的家也是这样 ...

随机推荐

  1. 基于VS Code创建Java command-line app

    由于国产化的原因,公司由.NET转向了Java阵营,之后会不定期分享一些技术转型中的体会.所谓Java的command-line app其实就是.NET项目中的Console Application, ...

  2. rxjs 常用的管道操作符

    操作符文档 api 列表 do -> tap catch -> catchError switch -> switchAll finally -> finalize map s ...

  3. CH #46A - 磁力块 - [分块]

    题目链接:传送门 描述在一片广袤无垠的原野上,散落着N块磁石.每个磁石的性质可以用一个五元组(x,y,m,p,r)描述,其中x,y表示其坐标,m是磁石的质量,p是磁力,r是吸引半径.若磁石A与磁石B的 ...

  4. [No0000155]为什么32位机器最大只能用到4GB内存

    在此之前先来了解一些计算机存储单位之间的关系以及计算机系统结构和PC硬件方面的一些知识. 一.计算机存储单位之间的关系 ,最小的存储单位. 个二进制位为一个字节(B),即1B = 8bit,最常用的单 ...

  5. Docker、kubernetes、微服务、SpringBoot/Cloud...好乱!到底要不要学?

    Docker.微服务日益火热的今天,相信标题上这些名词大家都不陌生.但也相信有很多同学并不够清楚他们的概念,不理解它们的关系,也可能有这样的疑惑:不知道跟我有没有关系?要不要学习?怎么去学习?学哪些东 ...

  6. PostgreSQL+PostGIS安装以及使用

    安装,参照:    https://www.cnblogs.com/ytwy/p/6817179.html 创建企业级地理文件数据库时报错," You must copy the lates ...

  7. Go编写的并行计算示例程序

    Go编写的并行计算示例程序 package main import "fmt" const ngoroute = 1000000 func f(left, right chan i ...

  8. mysql中建立索引的一些原则

    1.先存数据,再建索引 有索引的好处是搜索比较快但是在有索引的前提下进行插入.更新操作会很慢 2.不要对规模小的数据表建立索引,数据量超过300的表应该有索引:对于规模小的数据表建立索引 不仅不会提高 ...

  9. io.UnsupportedOperation: not readable

    两处错误一.你是用open打开一个文件,此时调用的是w写入模式,下面使用read是没有权限的,你得使用w+读写模式二.使用write写入一个字符s,但是此时并没有真正的写入,而是还存在与内存中.此时执 ...

  10. [administrative][lvm] lvm 分区修改

    默认安装的CentOS6.3操作系统,使用lvm分区.root挂载了50G,home挂载了1.5T. 由于需求要求,现在需要把home的1.5T全部移动到root下. 使用archiso启动,查看lv ...