早教吧作业答案频道 -->其他-->
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++求
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++很容易。
#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系统的基本功能所谓丑数,是...的网友还看了以下:
椭圆的准线方程是什么东西?练习上突然叫你求某椭圆的准线方程.可是教科书上提都没提过.我知道方程式是 2020-05-16 …
有关matlab程序的求助.n=size(a,1)表示什么,其中a是一个9行9列的举证. 2020-05-17 …
求解一道应用题.甲乙的成绩和184分,乙丙的平均成绩93.丙丁的成绩和是188分,甲比乙多1分.求 2020-05-20 …
解二元二次方程组 这个方程组怎么解,我想得到结果,有没有解方程组的求解器啊 2020-06-27 …
1系统的基本功能所谓丑数,是指因子只含2,3,5的数。编写一个程序,求第1500个只有2,3,5因 2020-07-10 …
关于两点直线方程式的求解?经过坐标轴上的点P(1,4)做直线a,分别交叉于坐标轴,求直线a的直线方 2020-07-30 …
一次方程组,解得公示有设么规律比如说N元一次方程组的求解公式 2020-08-02 …
对数方程组的求解alog28+b=10alog232+b=14求a,b的值麻烦讲解一下过程~ 2020-08-02 …
谁知道三元一次方程组的求解公式?二元一次方程组:ax+by=Acx=dy=Bx=dA-bB/ad- 2020-08-02 …
一类微分方程求解f(x,y)dxg(x,y)dy=0,也就是所谓的可分离变量的方程.是不是都是F( 2020-08-02 …