1:算数基本定理:任一大于1的自然数都可分解成若干质因数的连乘积,如果不计各质因数的顺序,这种分解是唯一的。如100=22*52。
参考题:https://vjudge.net/contest/277960#problem/C
思路:求出它的每个质因子的个数,然后用公式求出它的约数个数。如果b * b > a,那么值一定为0,其余部分可以枚举b。
记住这种题一般都要素数打表

2:
求前三位:

每一个数n都可以写作10t(t大多是小数),则此时nk可写作10^kt
n=10^t
nk=10kt
kt=x+y(x是整数部分,y是小数部分)

nk=10x * 10^y

因为x是整数,所示10x是1,10,100,1000…表示的是nk有多少位,
y是小数,10y表示的是nk的具体的数值。

所以我们要求nk的前a位,即求10(a-1+y)

(为什么是a-1? 答:指数函数10x,当x>0时,10x>1)

那么kt=k*log(10)n
y=fmod(kt,(int)kt)

数论总结
求后几位一般是mod (快速幂)eg:求后三位%1000
参考题:https://vjudge.net/contest/277960#problem/E

相关文章:

  • 2021-11-07
  • 2021-06-09
  • 2021-12-25
  • 2022-03-01
  • 2022-02-02
  • 2022-01-14
  • 2021-10-11
  • 2022-12-23
猜你喜欢
  • 2021-10-08
  • 2021-06-04
  • 2022-12-23
  • 2021-05-20
  • 2022-02-13
相关资源
相似解决方案