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; 
相关推荐
一只小bit2 小时前
Qt 网络:包含Udp、Tcp、Http三种协议的客户端实践手册
前端·c++·qt·页面
kimicsdn2 小时前
opentelemetry-demo currency cpp 项目编译流程分享
c++·cmake·libprotobuf-dev
闻缺陷则喜何志丹2 小时前
【动态规划】P9980 [USACO23DEC] Flight Routes G|普及+
c++·算法·动态规划·洛谷
橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——力扣 433 题:最小基因变化
数据结构·c++·算法·哈希算法
移幻漂流2 小时前
C/C++内存掌控之道:从内存泄漏到零开销抽象的进阶之路
java·c语言·c++
橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——力扣 1926 题:迷宫中离入口最近的出口
c++·算法·结构与算法
余衫马2 小时前
Qt for Python:PySide6 入门指南(下篇)
c++·python·qt
HalvmånEver2 小时前
Linux:信号初识上(信号一)
linux·运维·服务器·c++·系统架构·信号
HellowAmy2 小时前
我的C++规范 - 请转移到文件
开发语言·c++·代码规范