HDU6108《小C的倍数问题》
十月 13, 2019
1667
真·小学数学
Problem Description
根据小学数学的知识,我们知道一个正整数x是3的倍数的条件是x每一位加起来的和是3的倍数。反之,如果一个数每一位加起来是3的倍数,则这个数肯定是3的倍数。
现在给定进制P,求有多少个B满足P进制下,一个正整数是B的倍数的充分必要条件是每一位加起来的和是B的倍数。
Input
第一行一个正整数T表示数据组数(1<=T<=20)。
接下来T行,每行一个正整数P(2 < P < 1e9),表示一组询问。
Output
对于每组数据输出一行,每一行一个数表示答案。
Sample Input
1 |
|
Sample Output
1 |
|
解析
小 学 数 学
考虑进制表示的实质是
稍微变形一下
MATHJAX-SSR-711
然后注意到
把它代入进去
MATHJAX-SSR-712
发现前面几项都有一个
那么,当且仅当,即 x 各位数字之和 时,
one more thing
对于任意的自然数,如果 ,那么有
所以这题的思路已经很明显了,求的就是的因子个数
代码实现
1 |
|
- 本文作者:Handwer STD
- 本文链接:https://blog.handwer-std.top/2019-10-13/HDU6108/index.html
- 版权声明:本博客所有文章均采用 BY-NC-SA 许可协议,转载请注明出处!