凡人修c传(二十四)Codeforces Round #829 (Div. 1)B. Factorial Divisibility

传送门:Problem - B - Codeforces

最开始我看这道题很懵。看了题解才能领悟这个思路。这又双叒刷新了我对数学的认知,数学真的是博大精深。该题简单来讲就是判断给出一堆数的阶乘和能否被k的阶乘整除。那么其实我们不需要枚举的是大于等于k的数,因为这个数一定可以被k的阶乘整除。那么我们要枚举的应该是1到k-1的数。用map记录一下每一个数出现的次数(这里用hh来代替),hh[i]看是否可以整除i+1,如果不能,那就可以直接跳出输出no,如果可以则hh[i+1]+=hh[i]/(i+1)。这里用的是叠加。例如5个4的话,那该数就是4的倍数。

代码如下:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值