博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2017"百度之星"程序设计大赛 - 初赛(A)1001——HDU 6108【求因子数】【思维题】...
阅读量:6848 次
发布时间:2019-06-26

本文共 1087 字,大约阅读时间需要 3 分钟。

小C的倍数问题

 
 Accepts: 1990
 
 Submissions: 4931
 Time Limit: 2000/1000 MS (Java/Others)
 
 Memory Limit: 32768/32768 K (Java/Others)
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
110
Sample Output
3

  • 现在给定进制P,求有多少个B满足P进制下,一个正整数是B的倍数的充分必要条件是每一位加起来的和是B的倍数。
  • 只要求p-1的因数个数即为所求
  • 比如十进制数ab(两位数,十位为a, 个位为b)满足是B的倍数且每一位加起来的和也是B的倍数,则每一位加起来的和为a+b = Bk1(k1为整数), 而这个十进制数是 10a+b = Bk2(k2为整数), 做差得 9a = B(k1-k2), 即这个B可以是9的因数, 可取的个数就是9的因数的个数
  • 扩展开来, p进制两位数ab满足是B的倍数且每一位加起来的和也是B的倍数,则每一位加起来的和为a+b = Bk1(k1为整数), 而这个十进制数是 pa+b = Bk2(k2为整数), 做差得 (p-1)a = B(k1-k2),即这个B可以是(p-1)的因数, 可取的个数就是(p-1)的因数的个数
#include 
using namespace std;int main(){ int t; scanf("%d", &t); while (t--) { int p, ans = 0; scanf("%d", &p); p -= 1; for (int i = 1; i*i <= p; i++) { if (p%i == 0) { ans++; if (i*i != p) ans++; } } printf("%d\n", ans); }}

转载于:https://www.cnblogs.com/Archger/p/8451589.html

你可能感兴趣的文章
mysql添加外键语句
查看>>
Objective-C语法之动态类型(isKindOfClass, isMemberOfClass,id)等
查看>>
Django框架----路由系统、视图和模板(简单介绍)
查看>>
MySQL 添加审计功能
查看>>
动手动脑及课后实验整理集合
查看>>
初识webpack——webpack四个基础概念
查看>>
Bootstrap下拉菜单
查看>>
poj2250
查看>>
初识Hadoop
查看>>
动态规划
查看>>
单纯形法
查看>>
BFS POJ 3414 Pots
查看>>
python全栈开发 * 03 基本数据类型 * 180601
查看>>
Java web 1
查看>>
21.Spring Boot 使用Java代码创建Bean并注册到Spring中
查看>>
window.location.href的用法
查看>>
C# MVC中直接执行Js
查看>>
mac book下批量替换多个文件中的字符
查看>>
python IO编程-序列化
查看>>
9.回文数
查看>>