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; 
相关推荐
fqbqrr16 小时前
2606C++,C++构的多态
开发语言·c++
小欣加油16 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
Yolo_TvT17 小时前
C++:析构函数
c++
Hello:CodeWorld19 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
搬砖魁首21 小时前
基础能力系列 - 多线程2 - 条件变量
c++·rust·条件变量·原子类型·线程同步互斥
chase_my_dream21 小时前
C++ + SLAM 高频面试问题整理
开发语言·c++·面试
牛油果子哥q1 天前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
凡人叶枫1 天前
Effective C++ 条款04:确定对象被使用前已先被初始化
java·linux·开发语言·c++·嵌入式开发
不想写代码的星星1 天前
std::move 根本不移动,就像老婆饼里没有老婆
c++
redaijufeng1 天前
C++雾中风景7:闭包
c++·算法·风景