算法练习——数素数

题目

题目描述

令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;
}
相关推荐
小白菜又菜11 分钟前
Leetcode 516. Longest Palindromic Subsequence
算法·leetcode·职场和发展
℡☞小白☜ღ38 分钟前
信号量(semaphore)
算法
IT_Beijing_BIT1 小时前
C++ 的常见算法 之一
开发语言·c++·算法
日月星辰cmc1 小时前
【算法题解】部分洛谷题解(下)
算法
Coisinilove2 小时前
MATLAB——循环语句
开发语言·算法·matlab
tq022 小时前
Java数据结构-树的面试题
数据结构·面试·职场和发展
Jules_wwy2 小时前
查找——数据结构与算法 总结7
数据结构·查找
bigbigli_大李2 小时前
C++基础21 二维数组及相关问题详解
数据结构·c++·算法
PPPPPaPeR.3 小时前
TopK问题与堆排序
c语言·开发语言·c++·算法
卡戎-caryon4 小时前
【数据结构】06.栈&&队列
c语言·数据结构·算法·链表