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; 
相关推荐
rainbow688944 分钟前
EffectiveC++入门:四大习惯提升代码质量
c++
秋邱1 小时前
用 Python 写出 C++ 的性能?用CANN中PyPTO 算子开发硬核上手指南
开发语言·c++·python
我在人间贩卖青春1 小时前
C++之析构函数
c++·析构函数
我在人间贩卖青春2 小时前
C++之数据类型的扩展
c++·字符串·数据类型
wangjialelele2 小时前
平衡二叉搜索树:AVL树和红黑树
java·c语言·开发语言·数据结构·c++·算法·深度优先
苏宸啊2 小时前
C++栈和队列
c++
森G2 小时前
七、04ledc-sdk--------makefile有变化
linux·c语言·arm开发·c++·ubuntu
橘颂TA3 小时前
【测试】高效浏览器操作:基础功能与优化设置大全
c++·功能测试·职场和发展·测试·web测试
一只小小的芙厨3 小时前
寒假集训笔记·以点为对象的树形DP
c++·算法
艾莉丝努力练剑3 小时前
hixl vs NCCL:昇腾生态通信库的独特优势分析
运维·c++·人工智能·cann