早教吧 育儿知识 作业答案 考试题库 百科 知识分享

1系统的基本功能所谓丑数,是指因子只含2,3,5的数。编写一个程序,求第1500个只有2,3,5因子的数。2要求及提示数是从小到大排列的,第一个数是1,1=20*30*50。2.1程序执行过程本题目不

题目详情
1 系统的基本功能 所谓丑数,是指因子只含2,3,5的数。编写一个程序,求第1500个只有2,3,5因子的数。
2 要求及提示
数是从小到大排列的,第一个数是1,1 = 20 * 30 * 50。
2.1 程序执行过程
本题目不需要从键盘读入数据。结果输出时,为便于观察,要求以连乘的形式打印到屏幕上,格式如下(假设,x为找到的数,a、b、c为2、3、5的个数):
\x09\x09The 1500th number is x.
x = 2^a * 3^b * 5^c
2.2 算法要求及提示
(1)本题描述的实际上是一个数列,这个数列如下:
\x09\x091,2,3,4,5,6,8,9,10……
\x09\x091 = 20 * 30 * 50 2 = 21 * 30 * 50 3 = 20 * 31 * 50
4 = 22 * 30 * 50 5 = 20 * 30 * 51 6 = 21 * 31 * 50
\x09\x098 = 23 * 30 * 50 9 = 20 * 32 * 50 10 = 21 * 30 * 51
\x09\x09。。。。。。
\x09\x09题目要求的是该数列的第1500项。
(2)求解该问题时,比较有效的一个方法是,设一个变量n,和一个计数器count,count初始值为0。n从1开始,判断n的质因数是不是只有2、3和5。如果是说明n是数列中的数,count = count + 1;否则不是。然后n = n + 1,再重新判断,直至count = 1500。
用C++求
▼优质解答
答案和解析
#include
#include
int main()
{
int count = 0;
int num = 2*3*5;
int i=0,j=0,k=0;
while(count < 1500) {
int tmp = num++;
i=0,j=0,k=0;
if(tmp % (2*3*5)) {
continue;
}
while(!(tmp % 2)) {
i ++;
tmp = tmp /2;
}
while(!(tmp % 3)) {
j ++;
tmp = tmp /3;
}
while(!(tmp % 5)) {
k ++;
tmp = tmp /5;
}
count ++;
//printf("The %dth number is x. x=2^%d*3^%d*5^%d\n", count, i, j, k);
}
printf("The %dth number is x. x=2^%d*3^%d*5^%d\n", count, i, j, k);
return 0;
}
c版本,改成c++很容易。
看了 1系统的基本功能所谓丑数,是...的网友还看了以下:

下列有关叙述错误的是()A.化学反应的实质是原子的重新组合B.表示中和热的热化学方程式:2NaOH  2020-04-08 …

铝土矿(主要成分为Al2O3,还有少量杂质)是提取氧化铝的原料.提取氧化铝的工艺流程如下:(1)请  2020-05-12 …

用手通过一根绳子提重物,会感到手手受到一个向下的力,这个力的施力物体是什么?为什么?我知道了,老师  2020-05-14 …

种子结构中,将来能发育成一个植物体的是胚胚,它是种子的主要部分.菜豆种子在萌发的过程中营养由子叶子  2020-05-17 …

种子结构中,将来能发育成一个植物体的是胚胚,它是种子的主要部分.菜豆种子在萌发的过程中营养由子叶子  2020-05-17 …

如图菜豆种子示意图,下列判断正确的是()A.菜豆是双子叶植物B.完整地胚由1、2、4组成C.将来发  2020-05-17 …

以下是关于BSP方法中子系统和过程之间关系的描述,其中错误的是A.过程提供了合理的子系统边界B.子  2020-05-23 …

下列关于程序效率的描述错误的是( )。A.提高程序的执行速度可以提高程序的效率B.降低程序占  2020-05-23 …

英语翻译我要的开头是:子程子曰,「不偏之谓中;不易之谓庸.」中者,天下之正道.庸者,天下之定理.此  2020-05-24 …

下列关于子程序描述正确的是( )A.子程序只能被调用程序调用一次B.子程序返回指令RET可以用一条  2020-05-24 …