当前位置: 首页 > article >正文

Leecode刷题C语言之统计不是特殊数字的数字数量

 执行结果:通过

执行用时和内存消耗如下:

bool isPrime(int n){
    if(n<2){
        return false;
    }
    for(int i=2;i*i<=n;i++){
        if(n%i==0){
            return false;
        }
    }
    return true;
}
int nonSpecialCount(int l, int r) {
    int p=sqrt(l);
    int q = sqrt(r);
    int len = r-l+1;
    for(int i = p; i <=q; i++) {
        if(isPrime(i)&&i*i>=l) {
            len--;
        }
    }
    return len;
}

解题思路:

这段代码主要包含两个函数:isPrime 和 nonSpecialCount。下面分别解释这两个函数的思路。

isPrime 函数

这个函数用于判断一个整数 n 是否为质数。

  1. 判断边界条件
    • 如果 n 小于 2,直接返回 false,因为质数定义为在大于 1 的自然数中,除了 1 和它本身以外不再有其他因数的数。
  2. 检查因数
    • 从 2 开始,一直到 sqrt(n)(即 n 的平方根),逐个检查是否存在能够整除 n 的数。
    • 如果在这个范围内找到了一个数 i,使得 n % i == 0,说明 n 不是质数,返回 false
    • 如果循环结束都没有找到这样的 i,说明 n 是质数,返回 true

注意:只需要检查到 sqrt(n) 是因为如果一个数 n 不是质数,那么它必有一个因子不大于它的平方根。

nonSpecialCount 函数

这个函数用于计算在区间 [l, r] 内,有多少个整数不是某个质数的平方。

  1. 计算区间长度
    • 首先计算区间 [l, r] 的长度 len,即 r - l + 1
  2. 确定质数平方的范围
    • 计算 l 和 r 的平方根,分别为 p 和 q
    • 只需要考虑 [p, q] 范围内的质数,因为在这个范围外的质数的平方要么小于 l,要么大于 r,不在考虑范围内。
  3. 检查质数平方
    • 遍历 [p, q] 范围内的每个整数 i,使用 isPrime 函数判断 i 是否为质数。
    • 如果 i 是质数且 i * i 在区间 [l, r] 内,说明这个质数的平方在区间内,因此 len 需要减一。
  4. 返回结果
    • 最后返回调整后的 len,即区间 [l, r] 内不是某个质数平方的整数个数。

注意:这里的“特殊”指的是某个质数的平方,而函数名 nonSpecialCount 意味着计算“非特殊”的数量,即不是质数平方的数量。


http://www.kler.cn/a/405306.html

相关文章:

  • Android 分区相关介绍
  • vue2 src_消息订阅和发布(pubsub-js)
  • WebApis学习笔记,第二节:高级语法
  • Verilog HDL可综合与不可综合语句
  • 在centos7中安装SqlDeveloper的Oracle可视化工具
  • NIO 与传统 IO:深入理解与应用场景
  • xbh的比赛
  • Qt 的事件投递机制:从基础到实战
  • 动态调试对安全研究有什么帮助?
  • 设计模式之 模板方法模式
  • vue中路由缓存
  • Python创建虚拟环境报错:Error: Command......
  • 项目中排查bug的思路案例
  • 【Spring MVC】关于Spring MVC编程中与http请求的参数传递的详细介绍
  • 【MySQL系列】深入理解MySQL中的存储、排序字符集
  • Ubuntu20.04从零安装IsaacSim/IsaacLab
  • python内存分析
  • Qt-常用的显示类控件
  • Zookeeper集群搭建Centos环境下
  • ROS机器视觉入门:从基础到人脸识别与目标检测
  • 网络安全中常用浏览器插件、拓展
  • 生日主题的烟花特效HTML,CSS,JS
  • 20241121 android中树结构列表(使用recyclerView实现)
  • 【K8S系列】imagePullSecrets配置正确,但docker pull仍然失败,进一步排查详细步骤
  • java: spire.pdf.free 9.12.3 create pdf
  • Android 应用添加系统签名权限介绍