原题链接:蓝桥杯算法提高VIP-特殊的质数肋骨
解题思路:
注意事项:
参考代码:
深搜(dfs):
#include<bits/stdc++.h>//万能头文件
using namespace std;
int n1[4]={2,3,5,7};//质数肋骨的首位数字可能性
int n2[4]={1,3,7,9};//质数肋骨后几位的数字可能性
int n;//位数
bool is_prime(int x) //素数判断 {
for(int i=2;i*i<=x;i++)
if(x%i==0)
return false;
return true;
}
void dfs(int s,int i)//深搜函数 {
int ss;
if(i==n)
{
cout<<s<<endl;
return;
}//如果i==n,输出当前的s
for(int j=0;j<4;j++)
{//循环拼数
ss=s*10+n2[j];//当前s*10+后几位的可能数字
if(is_prime(ss))
dfs(ss,i+1);//如果ss为素数,则继续往下深搜
}
}
int main()//主函数开始 {
//freopen("superprime.in","r",stdin);
//freopen("superprime.out","w",stdout);
cin>>n;//读入n
if (n==1)
cout<<2<<endl<<3<<endl<<5<<endl<<7;//直接输出1的情况
else
{
for(int i=0;i<4;i++)//循环深搜
dfs(n1[i],1);
}
return 0;
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复