一道经典的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. C复习 (C premier plus和C和指针)

  2. 解决kali安装成功后没有声音的问题

    Kali Linux系统默认状态下,root用户是无法使用声卡的,也就没有声音.启用的方法如下: (1)在终端执行命令:systemctl --user enable pulseaudio (2)在/ ...

  3. Windows 编译安装 nginx 服务器 + rtmp 模块

    有关博客: <Windows 编译安装 nginx 服务器 + rtmp 模块>.<Ubuntu 编译安装 nginx>.<Arm-Linux 移植 Nginx> ...

  4. IDEA debug断点调试技巧

    Debug用来追踪代码的运行流程,通常在程序运行过程中出现异常,启用Debug模式可以分析定位异常发生的位置,以及在运行过程中参数的变化.通常我们也可以启用Debug模式来跟踪代码的运行流程去学习三方 ...

  5. yii框架中的下拉菜单和单选框

    yii中的下拉菜单: 第一种: <?= $form->field($model, 'parent_id')->dropDownList(ArrayHelper::map($data, ...

  6. AOP & 拦截器

    https://www.cnblogs.com/boywwj/p/7502185.html spring aop中@after-returning和@after,@afterThrowing,@Aro ...

  7. 用C#实现Rabbitmq应用的小实例

    RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件).RabbitMQ服务器是用Erlang语言编写的,而集群和故障转移是构建在开放电信平台框架上的.所有主要 ...

  8. 利用nfs-client-provisioner动态提供Kubernetes后端存储卷

    原文:https://www.kubernetes.org.cn/3894.html 利用NFS client provisioner动态提供Kubernetes后端存储卷 本文翻译自nfs-clie ...

  9. js的一些较为常见的语句算法题

    下面各题解法可能存在一些时间和空间复杂度问题,有些没有做到最优化,还请谅解!!! 1.用for循环实现10的阶乘. //使用for循环方法解答 var num = 10 var sum = 1; va ...

  10. JAVA - @WebServlet的使用方法

    在servlet3.0以后,我们可以不用再web.xml里面配置servlet,只需要加上@WebServlet注解就可以修改该servlet的属性了. 下面是@WebServlet的属性列表. 属性 ...