一道经典的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. 全栈项目|小书架|服务器端-NodeJS+Koa2实现首页图书列表接口

    通过上篇文章 全栈项目|小书架|微信小程序-首页水平轮播实现 我们实现了前端(小程序)效果图的展示,这篇文章来介绍服务器端的实现. 首页书籍信息 先来回顾一下首页书籍都有哪些信息: 从下面的图片可以看 ...

  2. MVC利用JQuery异步加载PartialView

    Javascript: $("#indexList").load('/Test/Index',{"id":"1","name&qu ...

  3. MySQLNonTransientConnectionException: Could not create connection to database server.

    MySQLNonTransientConnectionException: Could not create connection to database server. Spring整合mybati ...

  4. koa2--nodemailer实现邮箱验证

    依赖包安装: /** * koa-bodyparser用于把formData数据解析到ctx.request.body * 通过ctx.request.body访问请求的参数 * koa-redis用 ...

  5. Hive函数集锦

    一.内置运算符 1关系运算符 2.算术运算符 3.逻辑运算符 4.复杂类型函数 5.复杂类型函数应用

  6. centos下安装opencv

    根据项目需要,安装opencv并提供给开发使用,并且使用opencv提供python3的API接口.虽然不知道是个啥,还是简单了解下. opencv是什么? OpenCV的全称是Open Source ...

  7. 常用docker管理UI

    1. HumpBacks 特性 Web UI Supporting, Easy to use. Container Grouping and Isolation. Container Upgrades ...

  8. Linux操作系统的进程管理和作业管理

    Linux操作系统的进程管理和信号 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.lsof命令详解 1>.lsof概述 list open files查看当前系统文件的工 ...

  9. Pthon魔术方法(Magic Methods)-可调用对象

    Pthon魔术方法(Magic Methods)-可调用对象 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.可调用对象方法 __call__: 类中定义一个该方法,实例就可以像 ...

  10. Apache:编译和安装

    1.在Fedora / CentOS / Red Hat Enterprise Linux上安装 sudo yum install httpd sudo systemctl enable httpd ...