POJ 1142 Smith Numbers(史密斯数)
|
Description |
题目描述 |
|
While skimming his phone directory in 1982, Albert Wilansky, a mathematician of Lehigh University, noticed that the telephone number of his brother-in-law H. Smith had the following peculiar property: The sum of the digits of that number was equal to the sum of the digits of the prime factors of that number. Got it? Smith's telephone number was 493-7775. This number can be written as the product of its prime factors in the following way: 4937775= 3*5*5*65837 The sum of all digits of the telephone number is 4+9+3+7+7+7+5= 42,and the sum of the digits of its prime factors is equally 3+5+5+6+5+8+3+7=42. Wilansky was so amazed by his discovery that he named this kind of numbers after his brother-in-law: Smith numbers. As this observation is also true for every prime number, Wilansky decided later that a (simple and unsophisticated) prime number is not worth being a Smith number, so he excluded them from the definition. Wilansky published an article about Smith numbers in the Two Year College Mathematics Journal and was able to present a whole collection of different Smith numbers: For example, 9985 is a Smith number and so is 6036.However, Wilansky was not able to find a Smith number that was larger than the telephone number of his brother-in-law. It is your task to find Smith numbers that are larger than 4937775! |
阿尔伯特·威兰斯基是一位理海大学的数学家,在1982年浏览他自己的电话薄时,注意到他的表兄弟(Harold Smith)H. Smith的电话号码有有如下特点:各位上的数字相加等于分解质因数后各位上的数字相加。懂否?史密斯的电话号码是493-7775。这个数字可被分解质因数致如下形式: 4937775= 3*5*5*65837 这个电话号码各位数字的和是4+9+3+7+7+7+5= 42,并且与分解质因数后各位数字的和相等3+5+5+6+5+8+3+7=42。威兰斯基感觉很神奇就以他的表兄弟命名:史密斯数。 不过这个性质对每个质数都成立,因此威兰斯基后来把质数(分解不能)从史密斯数的定义中剔除了。 威兰斯基在the Two Year College Mathematics Journal发表了关于史密斯数的论文并且列出了一整套史密斯数:举个栗子,9985是史密斯数,6036也是。但是威兰斯基没能找到比他表兄弟电话号码4937775更大的史密斯数,你可以当条红领巾! |
|
Input |
输入 |
|
The input file consists of a sequence of positive integers, one integer per line. Each integer will have at most 8 digits. The input is terminated by a line containing the number 0. |
输入文件由一列正整数组成,每行一个整数。每个整数最多8位。数字0表示输入结束。 |
|
Output |
输出 |
|
For every number n > 0 in the input, you are to compute the smallest Smith number which is larger than n, and print it on a line by itself. You can assume that such a number exists. |
对于每个n>0的输入,你要算出大于n的最小史密斯数,输出一行。你可以认为结果是存在的。 |
|
Sample Input - 输入样例 |
Sample Output - 输出样例 |
|
4937774 0 |
4937775 |
【题解】
首先,这道题是水题,不然就会和某个人一样觉得要用Pollard's rho算法……
注意几点就可以了:
①可以暴力。②素数不是史密斯数。③从n+1开始找。
④题目描述和输入输出分开看,并不是要你找4937775后的史密斯数。
【代码 C++】
#include<cstdio>
#include<cstring>
#include<cmath>
int prime[];
void rdy(){
bool temp[];
memset(temp, , sizeof(temp));
prime[] = ;
int i = , j, pi = ;
for (i = ; i < ; i += ){
if (temp[i]) continue;
else{
for (j = i << ; j < ; j += i) temp[j] = ;
prime[++pi] = i;
}
}
prime[] = ;
}
int digitSum(int now){
int sum = ;
while (now) sum += now % , now /= ;
return sum;
}
int find(int now){
int i = , ed = sqrtf(now) + 0.5;
if (ed > ) ed = ;
for (; prime[i] <= ed; ++i){
if (now%prime[i] == ) return prime[i];
}
return ;
}
int change(int now){
int sum = , temp, stp = ;
while (now > ){
temp = find(now);
if (temp) sum += digitSum(temp), now /= temp, ++stp;
else sum += digitSum(now), now = ;
}
if (stp) return sum;
return ;
}
int main(){
rdy();
int n;
while (scanf("%d", &n)){
if (n++){
while (digitSum(n) != change(n)) ++n;
printf("%d\n", n);
}
else break;
}
return ;
}
POJ 1142
POJ 1142 Smith Numbers(史密斯数)的更多相关文章
- poj 1142 Smith Numbers
Description While skimming his phone directory in 1982, Albert Wilansky, a mathematician of Lehigh U ...
- POJ 1142 Smith Numbers(分治法+质因数分解)
http://poj.org/problem?id=1142 题意: 给出一个数n,求大于n的最小数,它满足各位数相加等于该数分解质因数的各位相加. 思路:直接暴力. #include <ios ...
- Smith Numbers POJ - 1142 (暴力+分治)
题意:给定一个N,求一个大于N的最小的Smith Numbers,Smith Numbers是一个合数,且分解质因数之后上质因子每一位上的数字之和 等于 其本身每一位数字之和(别的博客偷的题意) 思路 ...
- POJ 1142:Smith Numbers(分解质因数)
Smith Numbers Time Limit: 1000MS Memory Limit: 10000K Total Submiss ...
- Poj 2247 Humble Numbers(求只能被2,3,5, 7 整除的数)
一.题目大意 本题要求写出前5482个仅能被2,3,5, 7 整除的数. 二.题解 这道题从本质上和Poj 1338 Ugly Numbers(数学推导)是一样的原理,只需要在原来的基础上加上7的运算 ...
- A - Smith Numbers POJ
While skimming his phone directory in 1982, Albert Wilansky, a mathematician of Lehigh University,no ...
- Smith Numbers - PC110706
欢迎访问我的新博客:http://www.milkcu.com/blog/ 原文地址:http://www.milkcu.com/blog/archives/uva10042.html 原创:Smit ...
- UVA 10042 Smith Numbers(数论)
Smith Numbers Background While skimming his phone directory in 1982, Albert Wilansky, a mathematicia ...
- 【BZOJ1662】[Usaco2006 Nov]Round Numbers 圆环数 数位DP
[BZOJ1662][Usaco2006 Nov]Round Numbers 圆环数 Description 正如你所知,奶牛们没有手指以至于不能玩"石头剪刀布"来任意地决定例如谁 ...
随机推荐
- linux设备驱动归纳总结(八):1.总线、设备和驱动【转】
本文转载自:http://blog.chinaunix.net/uid-25014876-id-109733.html linux设备驱动归纳总结(八):1.总线.设备和驱动 xxxxxxxxxxxx ...
- scala模拟一个timer
直接上代码: package com.test.scalaw.test.demo import java.util.Date /** * 模拟一个定时timer */ object Timer { d ...
- ES6,ES2105核心功能一览,js新特性详解
ES6,ES2105核心功能一览,js新特性详解 过去几年 JavaScript 发生了很大的变化.ES6(ECMAScript 6.ES2105)是 JavaScript 语言的新标准,2015 年 ...
- awk,perl,python的命令行参数处理
Python,Perl,Bash命令行参数 Part I 日常经常性的和Perl,Python,Bash打交道,但是又经常性的搞混他们之间,在命令行上的特殊性和index的区别,Python真的是人性 ...
- jenkins+jmeter+ant搭建接口测试平台
接口测试的重点是检查数据的交换,传递和控制管理过程以及系统间的相互逻辑依赖关系. 接口测试的流程 项目启动后,测试人员要尽早拿到接口测试文档. 开始编写接口测试用例 将接口测试用例部署到持续集成的测试 ...
- PHP array_count_values() 函数用于统计数组中所有值出现的次数。
定义和用法 array_count_values() 函数用于统计数组中所有值出现的次数. 本函数返回一个数组,其元素的键名是原数组的值,键值是该值在原数组中出现的次数. 语法 array_count ...
- iOS身份证的正则验证
在ios项目的开发中可能很多地方都需要用到身份证校验,一般在开发的时候很多人都是直接百度去网上荡相关的正则表达式和校验代码,但是网上疯狂粘贴复制的校验代码本身也可能并不准确,可能会有风险,比如2013 ...
- 使用percona xtradb cluster的IST方式添加新节点
使用percona xtradb cluster的IST(Incremental State Transfer)特性添加新节点,防止新节点加入时使用SST(State SnapShop Transfe ...
- 每日一九度之 题目1039:Zero-complexity Transposition
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3372 解决:1392 题目描述: You are given a sequence of integer numbers. Zero-co ...
- 发现一个jq的问题
用jq对checkbox的checked属性进行操作时,使用$(‘#id’).attr(‘checked’, true);竟然无效,改成$(‘#id’).prop(‘checked’, true);才 ...