数论总结

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值