解题思路:





注意事项:





参考代码:

深搜(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;
}


点赞(4)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 3 条评论

跟着帮主混江湖 4年前 回复TA
你这个输出超过限制了,比答案长了两倍,但是我觉得你这个逻辑没有问题,不知道哪出了问题
lalalala 6年前 回复TA
@Spperman Me too!!
Spperman 6年前 回复TA
#include<bits/stdc++.h>//万能头文件
我喜欢!