一道经典的BFS

用四个for搜索四位就行了,只要能推出怎么只变4位中的一位就很水了

 #include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
#include<cmath>
using namespace std;
int t;
int n,m;
int book[]={};//记录有没有搜过
struct node//x表示现在的数,step表示当前的次数
{
int x;
int step;
};
queue<node> q;//广搜队列
bool zyc_pd(int x)//判断素数
{
if(x==||x==)return false;
else if(x==||x==)return true;
else
{
for(int i=;i<=(int)sqrt(x);i++)
{
if(x%i==)return false;
}
return true;
} }
void bfs()
{
int x1,step1,i;
while(!q.empty())
{
node tmp;
tmp=q.front();
q.pop();
x1=tmp.x;//赋初始值
step1=tmp.step;//赋初始值
//cout<<x1<<endl;
if(x1==m)//如果搜到结果,输出
{
cout<<step1<<endl;
return;
}
for(i=;i<=;i+=)//个位,从一到九的奇数(因为是素数)
{
int yy=x1/*+i;//去掉个位再加上搜到的个位
if(yy!=x1&&!book[yy]&&zyc_pd(yy))//不能与上一步数一样+不能重复搜+是素数
{
book[yy]=;//标记为搜过
node temp;
temp.x=yy;//制为当前的值
temp.step=step1+;//搜索次数加1
q.push(temp);
}
}
for(i=;i<=;i++)//十位同理
{
int yy=x1/*+i*+x1%;
if(yy!=x1&&!book[yy]&&zyc_pd(yy))
{
book[yy]=;
node temp;
temp.x=yy;
temp.step=step1+;
q.push(temp);
}
}
for(i=;i<=;i++)//百位同理
{
int yy=x1/*+i*+x1%;
if(yy!=x1&&!book[yy]&&zyc_pd(yy))
{
book[yy]=;
node temp;
temp.x=yy;
temp.step=step1+;
q.push(temp);
}
}
for(i=;i<=;i++)//千位
{
int yy=i*+x1%;//只换千位
if(yy!=x1&&!book[yy]&&zyc_pd(yy))
{
book[yy]=;
node temp;
temp.x=yy;
temp.step=step1+;
q.push(temp);
}
}
}
cout<<"Impossible"<<endl;//如果搜不到输出Impossible
return;
}
int main()
{
cin>>t;
while(t--)
{
while(!q.empty())q.pop();//清空队列
cin>>n>>m;
memset(book,,sizeof(book));//初始化book数组
book[n]=;//把book【n】制为搜过
node tmp;
tmp.x=n;//当前的数为n
tmp.step=;//当前步数为0
q.push(tmp);
bfs();
}
return ;
}
请各位大佬斧正(反正我不认识斧正是什么意思)

洛谷 UVA12101 Prime Path 题解的更多相关文章

  1. 洛谷P2832 行路难 分析+题解代码【玄学最短路】

    洛谷P2832 行路难 分析+题解代码[玄学最短路] 题目背景: 小X来到了山区,领略山林之乐.在他乐以忘忧之时,他突然发现,开学迫在眉睫 题目描述: 山区有n座山.山之间有m条羊肠小道,每条连接两座 ...

  2. 【洛谷P3960】列队题解

    [洛谷P3960]列队题解 题目链接 题意: Sylvia 是一个热爱学习的女孩子. 前段时间,Sylvia 参加了学校的军训.众所周知,军训的时候需要站方阵. Sylvia 所在的方阵中有 n×m ...

  3. 洛谷P2312 解方程题解

    洛谷P2312 解方程题解 题目描述 已知多项式方程: \[a_0+a_1x+a_2x^2+\cdots+a_nx^n=0\] 求这个方程在 \([1,m]\) 内的整数解(\(n\) 和 \(m\) ...

  4. 洛谷P1577 切绳子题解

    洛谷P1577 切绳子题解 题目描述 有N条绳子,它们的长度分别为Li.如果从它们中切割出K条长度相同的 绳子,这K条绳子每条最长能有多长?答案保留到小数点后2位(直接舍掉2为后的小数). 输入输出格 ...

  5. 洛谷P2507 [SCOI2008]配对 题解(dp+贪心)

    洛谷P2507 [SCOI2008]配对 题解(dp+贪心) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1299251 链接题目地址:洛谷P2507 [S ...

  6. 洛谷 P1220 关路灯 题解

    Description 有 $n$ 盏路灯,每盏路灯有坐标(单位 $m$)和功率(单位 $J$).从第 $c$ 盏路灯开始,可以向左或向右关闭路灯.速度是 $1m/s$.求所有路灯的最少耗电.输入保证 ...

  7. 【洛谷P3410】拍照题解(最大权闭合子图总结)

    题目描述 小B有n个下属,现小B要带着一些下属让别人拍照. 有m个人,每个人都愿意付给小B一定钱让n个人中的一些人进行合影.如果这一些人没带齐那么就不能拍照,小B也不会得到钱. 注意:带下属不是白带的 ...

  8. [BZOJ 3039&洛谷P4147]玉蟾宫 题解(单调栈)

    [BZOJ 3039&洛谷P4147]玉蟾宫 Description 有一天,小猫rainbow和freda来到了湘西张家界的天门山玉蟾宫,玉蟾宫宫主蓝兔盛情地款待了它们,并赐予它们一片土地. ...

  9. 洛谷 P3695 CYaRon!语 题解 【模拟】【字符串】

    大模拟好啊! 万一远古计算机让我写个解释器还真是得爆零了呢. 题目背景 「千歌です」(我是千歌).「曜です」(我是曜).「ルビィです」(我是露比).「3人合わせて.We are CYaRon! よろし ...

随机推荐

  1. Deleaker – 内存泄漏猎人(RAD Studio 的附加组件)

    程序员面临(并希望我们意识到)的常见问题之一是内存泄漏或任何其他类型的资源泄漏.例如,Windows限制了进程一次可以分配的GDI或USER32对象的数量.当事情走错路时,您可能希望拥有一些工具来帮助 ...

  2. 文件包含lfi

    CG-CTF web(文件包含漏洞) 参考链接:https://blog.csdn.net/qq_34072526/article/details/89431431 php://filter 的使用: ...

  3. 关于 exynos 4412 按键中断 异步通知

    以下是驱动测试代码: //内核的驱动代码 #include <linux/init.h> #include <linux/module.h> //for module_init ...

  4. KNN-k近邻算法

    目录 KNN-k近邻算法 一.KNN基础 二.自己写一个knn函数 三.使用sklearn中的KNN 四.自己写一个面向对象的KNN 五.分割数据集 六.使用sklearn中的鸢尾花数据测试KNN 七 ...

  5. sublime配置python环境及快捷键

    sublime配置python环境 参考链接:https://blog.csdn.net/VertigozZ/article/details/54574006 快捷键的配置:https://www.c ...

  6. maven安装配置 每次都百度,麻烦

    JDK已经安装 1. 下载:https://maven.apache.org/download.cgi 2.  解压 D:\Program Files\maven 配置环境变量 新建环境变量MAVEN ...

  7. 一张图看懂SharpCapture

    通过下面的图片,可以瞬间看懂整个类库的脉络.

  8. [JLOI2014]松鼠的新家 (树剖)

    题目 P3258 [JLOI2014]松鼠的新家 解析 非常裸的一道树剖题 链上修改+单点查询的板子 记录一下所经过的点\(now[i]\),每次更新\(now[i-1]到now[i]\) 我们链上更 ...

  9. Java自学-控制流程 break

    Java的break语句 结束循环 示例 1 : break; 直接结束当前for循环 public class HelloWorld { public static void main(String ...

  10. 结对项目(java实现)

    一 .Github项目地址:https://github.com/734635746/MyApp 二.PSP表格 PSP2.1 Personal Software Process Stages 预估耗 ...