zoj(1095)
2016-05-23 20:37
316 查看
A number whose only prime factors are 2,3,5 or 7 is called a humble number. The sequence 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 12, 14, 15, 16, 18, 20, 21, 24, 25, 27, ... shows the first 20 humble numbers.
Write a program to find and print the nth element in this sequence.
n with 1 <= n <= 5842. Input is terminated by a value of zero (0) for
n.
number.". Depending on the value of n, the correct suffix "st", "nd", "rd", or "th" for the ordinal number
nth has to be used like it is shown in the sample output.
Write a program to find and print the nth element in this sequence.
Input Specification
The input consists of one or more test cases. Each test case consists of one integern with 1 <= n <= 5842. Input is terminated by a value of zero (0) for
n.
Output Specification
For each test case, print one line saying "The nth humble number isnumber.". Depending on the value of n, the correct suffix "st", "nd", "rd", or "th" for the ordinal number
nth has to be used like it is shown in the sample output.
Sample Input
1 2 3 4 11 12 13 21 22 23 100 1000 5842 0
Sample Output
The 1st humble number is 1. The 2nd humble number is 2. The 3rd humble number is 3. The 4th humble number is 4. The 11th humble number is 12. The 12th humble number is 14. The 13th humble number is 15. The 21st humble number is 28. The 22nd humble number is 30. The 23rd humble number is 32. The 100th humble number is 450. The 1000th humble number is 385875. The 5842nd humble number is 2000000000. 题目大意:
求第n个丑数
丑数的质数因子只有2,3,7,9:
代码:
#include<iostream> #include<cstdio> using namespace std; int minx(int a,int b) { return a>b?b:a; } int a[5843]; int main() { int p2,p3,p5,p7,i; p2=p3=p5=p7=1; i=2; int n; a[1]=1; while(i<=5842) { a[i]=minx(minx(2*a[p2],3*a[p3]),minx(5*a[p5],7*a[p7])); if(a[i]==2*a[p2]) p2++; if(a[i]==3*a[p3]) p3++; if(a[i]==5*a[p5]) p5++; if(a[i]==7*a[p7]) p7++; i++; } while(scanf("%d",&n) && n) { if(n%100==11 || n%100==12 || n%100==13) printf("The %dth humble number is %d.\n",n,a ); else if(n%10==1) printf("The %dst humble number is %d.\n",n,a ); else if(n%10==2) printf("The %dnd humble number is %d.\n",n,a ); else if(n%10==3) printf("The %drd humble number is %d.\n",n,a ); else printf("The %dth humble number is %d.\n",n,a ); } return 0; }
相关文章推荐
- 简单的四则运算
- 数的奇偶性
- ACMer博客瀑布流分析
- ACM程序设计大赛题目分类
- 计算字符串最后一个单词长度
- ACM网址
- 1272 小希的迷宫
- 1272 小希的迷宫
- hdu 1250 大数相加并用数组储存
- 矩阵的乘法操作
- 蚂蚁爬行问题
- 蚂蚁爬行问题
- 求两个数的最大公约数【ACM基础题】
- 打印出二进制中所有1的位置
- 杭电题目---一只小蜜蜂
- HDOJ 1002 A + B Problem II (Big Numbers Addition)
- 初学ACM - 半数集(Half Set)问题 NOJ 1010 / FOJ 1207
- 初学ACM - 组合数学基础题目PKU 1833
- POJ ACM 1002
- POJ 2635 The Embarrassed Cryptographe