GESP 23年6月2级 找素数

【题目链接】

一本通 4007 找素数

洛谷 B3840 找素数


【题目考点】

  1. 基础数论(质数、因数);

  2. 循环结构(嵌套);

  3. 枚举法;


【解题逻辑】

解法1:

  1. 枚举整数范围 [A, B] 内的每一个整数 i;

  2. 枚举每个数字i的因数范围(1~i),统计i的因数个数;

  3. 根据因数个数判断是否为质数:

质数:只有1和本身两个因数;

  1. 统计质数个数;

解法2:

  1. 枚举整数范围 [A, B] 内的每一个整数 i;

  2. 对每个整数i,使用标记法初始化"是质数"的标记;

  3. 验证 i 是否符合质数定义:

枚举 2 ~ i-1 之间的所有整数 j,验证 j 是否为 i 的因数;若存在因数,将标记为非质数;

  1. 根据标记统计质数个数;

【题解代码】

解法1:

  1. 输入两个整数A,B;
cpp 复制代码
int A,B;
cin>>A>>B;
  1. 统计范围内的素数个数;
cpp 复制代码
int cnt=0;
  1. 枚举A~B之间所有的数字;
cpp 复制代码
for(int i=A;i<=B;i++){
    // 判断i是否为质数
    // 标记法: 假设是质数(2~i之间没有因数) 
    int f=1;
    for(int j=2;j<i;j++){
        if(i%j==0){// 如果出现因数 
            f=0;//标记为不是质数 
        }
    }
    // 根据标记判定i是否为质数
    // 如果f为1,则统计质数个数 
    if(f) cnt++; 
} 
  1. 输出范围内质数个数;
cpp 复制代码
cout<<cnt; 

解法2:

  1. 输入两个整数A,B;
cpp 复制代码
int A,B;
cin>>A>>B;
  1. 统计范围内的素数个数;
cpp 复制代码
int cnt=0;
  1. 枚举A~B之间所有的数字;
cpp 复制代码
for(int i=A;i<=B;i++){
    // 统计i的因数个数
    int p=0;
    for(int j=1;j<=i;j++){
        if(i%j==0){// 能被j整除,是j的因数
            p++;
        }
    }
    if(p==2){// i是质数
        cnt++;
    }
} 
  1. 输出范围内质数个数;
cpp 复制代码
cout<<cnt; 
相关推荐
端平入洛13 小时前
delete又未完全delete
c++
端平入洛2 天前
auto有时不auto
c++
哇哈哈20212 天前
信号量和信号
linux·c++
多恩Stone2 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
蜡笔小马2 天前
21.Boost.Geometry disjoint、distance、envelope、equals、expand和for_each算法接口详解
c++·算法·boost
超级大福宝2 天前
N皇后问题:经典回溯算法的一些分析
数据结构·c++·算法·leetcode
weiabc2 天前
printf(“%lf“, ys) 和 cout << ys 输出的浮点数格式存在细微差异
数据结构·c++·算法
问好眼2 天前
《算法竞赛进阶指南》0x01 位运算-3.64位整数乘法
c++·算法·位运算·信息学奥赛
yyjtx2 天前
DHU上机打卡D31
开发语言·c++·算法
czxyvX3 天前
020-C++之unordered容器
数据结构·c++