算法练习——数素数

题目

题目描述

令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;
}
相关推荐
z落落15 分钟前
C# Hashtable 哈希表+SortedList 有序键值对集合
数据结构·散列表
Brilliantwxx19 分钟前
【C++】 深入理解红黑树:实现与原理全解
数据结构·c++·笔记·算法·青少年编程·红黑树
人道领域26 分钟前
【LeetCode刷题日记】108.将有序数组转换为二叉搜索树
java·算法·leetcode
Dlrb121140 分钟前
数据结构-排序算法
数据结构·算法·排序算法·插入排序·堆排序·希尔排序·快速排序
过期动态40 分钟前
【LeetCode 热题 100】无重复字符的最长子串
java·数据结构·spring boot·算法·leetcode·职场和发展
莫等闲-2 小时前
leetcode42. 接雨水 leetcode84.柱状图中最大的矩形
数据结构·c++·算法·leetcode
unicrom_深圳市由你创科技2 小时前
历史数据存储量太大,怎么处理?数据压缩/归档策略?
算法
浅念-2 小时前
LeetCode 记忆化搜索 刷题总结
数据结构·算法·leetcode·职场和发展·深度优先·dfs
菜菜的顾清寒2 小时前
力扣HOT100(44)对称二叉树
数据结构·算法·leetcode
六bring个六2 小时前
c/c++面试踩坑笔记
c语言·数据结构·c++