算法练习——数素数

题目

题目描述

令Pi表示第i(i从1开始计数)个素数。现任给两个正整数M <= N <= 10000,请输出PM到PN的所有素数。

输入描述:

输入在一行中给出M和N,其间以空格分隔。

输出描述:

输出从PM到PN的所有素数,每10个数字占1行,其间以空格分隔,但行末不得有多余空格。

输入例子:
复制代码
5 27
输出例子:
复制代码
11 13 17 19 23 29 31 37 41 43
47 53 59 61 67 71 73 79 83 89
97 101 103

代码

线性筛素数

cpp 复制代码
#include<iostream>
using namespace std;

const int N = 105000;
int p[N], idx = 1;
bool st[N];

void get_primes() {
    for(int i = 2; i < N; i ++ ) {
        if(!st[i]) p[idx ++ ] = i;
        for(int j = 1; p[j] <= N / i; j ++ ) {
            st[i * p[j]] = true;
            if(i % p[j] == 0) break;
        } 
    }
}

int main() {
    int m, n;
    cin >> m >> n;

    get_primes();

    int cnt = 0;
    for(int i = m; i <= n; i ++ ) {
        if(cnt == 0) printf("%d", p[i]);
        else if(cnt % 10 == 0) printf("\n%d",p[i]);
        else printf(" %d", p[i]);
        cnt ++;
    }
    return 0;
}
相关推荐
T.Ree.20 分钟前
【数据结构】_树和二叉树
c语言·开发语言·数据结构
wuqingshun31415942 分钟前
蓝桥杯17. 机器人塔
c++·算法·职场和发展·蓝桥杯·深度优先
图灵科竞社资讯组1 小时前
图论基础:图存+记忆化搜索
算法·图论
chuxinweihui1 小时前
数据结构——栈与队列
c语言·开发语言·数据结构·学习·算法·链表
爱编程的鱼2 小时前
C# 结构(Struct)
开发语言·人工智能·算法·c#
啊我不会诶2 小时前
CF每日4题
算法
uhakadotcom2 小时前
人工智能如何改变医疗行业:简单易懂的基础介绍与实用案例
算法·面试·github
山北雨夜漫步3 小时前
机器学习 Day14 XGboost(极端梯度提升树)算法
人工智能·算法·机器学习
到底怎么取名字不会重复4 小时前
Day10——LeetCode15&560
c++·算法·leetcode·哈希算法·散列表