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; 
相关推荐
Darkwanderor1 天前
什么数据量适合用什么算法
c++·算法
超绝振刀怪1 天前
【C++多态】
开发语言·c++
zc.ovo1 天前
河北师范大学2026校赛题解(A,E,I)
c++·算法
学嵌入式的小杨同学1 天前
STM32 进阶封神之路(三十九)FreeRTOS 临界区、挂起 / 删除、钩子函数、调度底层原理|从应用到内核深度解析
c++·stm32·单片机·嵌入式硬件·mcu·硬件架构·pcb
oioihoii1 天前
Cursor根本无法调试C++
开发语言·c++
是娇娇公主~1 天前
Lambda表达式详解
数据结构·c++
leaves falling1 天前
C++ string 类:从入门到模拟实现
开发语言·c++
样例过了就是过了1 天前
LeetCode热题100 柱状图中最大的矩形
数据结构·c++·算法·leetcode
liuyao_xianhui1 天前
优选算法_最小基因变化_bfs_C++
java·开发语言·数据结构·c++·算法·哈希算法·宽度优先
cch89181 天前
易语言与C++:编程语言终极对决
开发语言·c++