955C. Sad powers(思维)

955C. Sad powers(思维)

题目链接:传送门

思路:对于1到n的满足 a b = x a^b=x ab=x的数 x x x(幂次 b b b>1)。

我们可以将之分为两种,一种是 b = 2 b=2 b=2,另一种 b > 2 b>2 b>2且不是完全平方数的个数。

对于第一种情况( b = = 2 b==2 b==2),即我们计算完全平方数的个数,这部我们可以二分 O ( l o g n ) O(logn) O(logn)

对于第二种情况( b > 2 b>2 b>2),因为 b = 3 b=3 b=3时这样数最多只有 1 0 18 / 3 = 1 0 6 10^{18/3}=10^6 1018/3=106种, b > 3 b>3 b>3的则更少,所以这种情况的数我们可以暴力预处理。

但是第二种情况可能有重复计算,我们去重即可。但是第一种情况和第二种情况可能也有重复计算,我们再筛去第二种情况的完全平方数。

这样我们计算 f ( n ) f(n) f(n)即小于等于 n n n,满足

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值