一道经典的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. FastReport For Delphi7 通用安装方法

    安装前请册除原有的FR控件. 1. "Tools|Environmet options..."中的"Library"标签面下"Library path ...

  2. 【Python爬虫案例学习】python爬取淘宝里的手机报价并以价格排序

    第一步: 先分析这个url,"?"后面的都是它的关键字,requests中get函数的关键字的参数是params,post函数的关键字参数是data, 关键字用字典的形式传进去,这 ...

  3. 53 容器(八)——TreeMap 红黑树

    红黑树是比较难以理解的一种数据结构.它能从10亿数据中进行10几次比较就能查找到需要的数据.效率非常高. 理解起内部结构也难. 现阶段我们知道有这种东西就行了. 参考文章: https://www.j ...

  4. zookeeper从入门到精通视频教程(含网盘下载地址)

    Zookeeper视频教程链接:https://pan.baidu.com/s/1V9YZN5F3sTKQJOhiDt9hnA 提取码:rtgl

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

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

  6. HTTP响应状态

    状态码分类 状态码详解 状态码 英文提示 说明 100 Continue 继续 101 Switching Protocols 切换协议.服务器根据客户端的请求切换协议.只能切换到更高级的协议,例如, ...

  7. jwt的思考

    什么是jwt jwt的问题 jwt的是实践 https://www.pingidentity.com/en/company/blog/posts/2019/jwt-security-nobody-ta ...

  8. 2.NET Core设定数据库种子

    1.使用以下代码在 Models 文件夹中创建一个名为 SeedData 的新类: using Microsoft.EntityFrameworkCore;using Microsoft.Extens ...

  9. EF CodeFirst Dome学习

    创建ConsoleDome控制台应用程序 从NuGet包管理器安装EntityFramework 创建DbContextDome类并继承DbContext public class DbContext ...

  10. linq 注意事项

    //linq分组需要注意的是into是在原表的基础上创建新的表进行排序 //new 是新表的字段,可以创建新的字段可以获取当前分组的没一个组的条数 var q = from p in list gro ...