无平方因子的数(数论好题)

这是一篇关于数论的博客,讨论了如何找出区间[n,m]内无平方因子的正整数数量。由于直接枚举会超时,文章介绍了类似素数筛选的方法,即对所有不超过sqrt(m)的素数p,筛掉p^2的倍数。博主提供了代码实现,并声称经过部分数据验证正确性。" 93724891,8223053,Redis实现的分布式锁详解,"['Redis', '分布式锁', 'Java', '数据库', '高并发']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:(题目跟分析基本都是书上,我只是敲几个代码跟大家分享)

无平方因子的数。 给出正整数n,m。区间[n,m]内  “无平方因子” 的数有多少个??

整数p无平方因子,当且仅当存在k>1,使得p是k^2的倍数.    1<=n<=m<=10^12;  n-n<=10^7

分析:

     直接枚举肯定会超时,

     使用的方法和筛选素质类似的,对于不超过 sqrt(m)的所有素数p,筛掉区间[n,m]内p^2的倍数

    以下是我的写代码(没有提交过OJ,但我尝试过一些数据,没有错。如果不妥还望指出

  

<span style="font-size:24px;">#include"stdio.h"
#include"stdlib.h"
#include"string.h" 
#include"math.h
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值