东华OJ-基础题-127-我素故我在(C++)

  • 问题描述
    有这样一种素数叫纯素数(YY出来的名字),当它是一个多位数的时候,你把它的末位去掉之后余下的数依然是一个素数。比如说2393,2393 本身是一个素数,它的末位去掉之后,余下的是239。239 是一个素数,它的末位去掉之后,余下的是23 。23是一个素数,它的末位去掉之后,余下的是2 。2依然还是一个素数。纯素数的长度叫做"维"。2393 是一个4维素数。3797也是一个4维素数。
  • 输入说明
    第一行先给出一共有多少组数据N(N<=1000),接下来有N组数据.

每组包括一个整数T(1<=T<=8)。

  • 输出说明
    按照从小到大的顺序输出所有的T维纯素数。
  • 输入范例
cpp 复制代码
3
8
1
4
  • 输出范例
cpp 复制代码
23399339
29399999
37337999
59393339
73939133
2
3
5
7
2333
2339
2393
2399
2939
3119
3137
3733
3739
3793
3797
5939
7193
7331
7333
7393

感想:1.写个函数用于判断是否是质数
2. 生成拼接纯素数,把1维、2维、3维...8维的纯素数都找到存放到各个vector里
3. 直接输出所需要的n维纯素数
By the way: 一开始用的暴力破解,一个一个累加去判断是否是纯素数,结果能输出来正确结果,但花费时间较长,OJ里TLE超时了,不得不优化算法,根据纯素数特征,找到关键是拼接出纯素数!!大大减少了时间复杂度哇。

代码如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

vector<int> PurePrimes[9];

bool isPrime(int n) {
    if(n<2) return false;
    if(n==2) return true;
    if(n%2 == 0) return false;//偶数直接排除
    for(int i =3; i*i<=n; i+=2) {//只检查能否被奇数整除
        if(n%i == 0)
            return false;
    }
    return true;
}

void generatePurePrime() {
    PurePrimes[1] = {2,3,5,7};
    // 逐层构造2~8维纯素数
    //构造纯素数,在前一个维度的数字上直接后面加上1/3/7/9再判断是否是素数
    for( int dim = 2; dim<=8; ++dim) {
        for(size_t cur = 0; cur<PurePrimes[dim-1].size(); ++cur) {
            int current = PurePrimes[dim-1][cur],generated_num;
            for(int last = 1; last<=9; last+=2) { //下一位只能是1/3/7/9
                if(last == 5)
                    continue;
                generated_num = current*10+last;
                if(isPrime(generated_num))
                    PurePrimes[dim].push_back(generated_num);

            }
        }
    }
}


int main() {
    generatePurePrime();// 预生成所有维度的纯素数(只执行一次,提升查询效率)
    int N;
    cin >> N;
    int n;
    while(N--) {
        cin>>n;//n维 1~8
        for(auto num : PurePrimes[n]) {
            cout<<num<<endl;
        }
    }

    return 0;
}
相关推荐
ab1515171 小时前
2.13完成101、102、89
开发语言·c++·算法
切糕师学AI1 小时前
NFS(网络文件系统)详解
开发语言·网络·php
芝士爱知识a1 小时前
[2026深度测评] AI期权交易平台推荐榜单:AlphaGBM领跑,量化交易的新范式
开发语言·数据结构·人工智能·python·alphagbm·ai期权工具
overmind1 小时前
oeasy Python 113 内置函数sorted中使用 reverse和key
开发语言·python
黎潇lulu2 小时前
Java运算符基础知识
java·开发语言
HAPPY酷2 小时前
C++中类常见的函数分类
java·开发语言·c++
weixin_449173652 小时前
java使用poi保存表格和图片到word文件中
java·开发语言·word
好家伙VCC2 小时前
# 光计算驱动的编程范式革新:用Python实现光子神经网络模拟器在传统电子计算架构逼近物理极限的今天,**光计算**正
java·开发语言·python·神经网络
梵刹古音2 小时前
【C++】 虚指针(vptr)与虚函数表(vtable)
开发语言·c++