早教吧作业答案频道 -->其他-->
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系统的基本功能所谓丑数,是...的网友还看了以下:
关于while的题目Hewillbewatchingheranxiously()sheswimsth 2020-03-31 …
含有主谓宾的句子要这样写1.xxxxxxxxxxxxxxxxx2.xxxxxxxxxxxxxxxx 2020-05-13 …
过去进行时时间状语从句中的谓语动词要用过去式吗1、过去进行时时间状语从句中的谓语动词要用过去式吗? 2020-05-13 …
为什么西班牙语的否定词no要插在主语和谓语动词之间我知道德语都是谓语要紧贴着主语的,否定词放哪儿也 2020-05-14 …
主谓宾的一些问题?主谓宾是什么==.我吃饭主宾谓1、宾语是不是动作的对象?2、位于通常指的是什么? 2020-05-16 …
一种什棉糖由奶糖水果糖和酥糖混合而成奶糖和水果糖质量比5;4酥糖的质量占总质量的4/1要60克的什 2020-05-23 …
一种什棉糖由奶糖水果糖和酥糖混合而成奶糖和水果糖质量比5;4酥糖的质量占总质量的4/1要60克的什 2020-05-23 …
关于谓语动词加s的问题我知道第三人称要谓语要加s,那么newspaper、thebook之类的物体 2020-06-03 …
1.要除去CO中少量的二氧化碳,可通入A.灼热氧化铜B.澄清石灰水C.水D.浓硫酸2.含有相等原子 2020-06-07 …
敏而好学,不耻下问,是以谓之文也中“以谓”和“文”的意思.尤其是文,一定要解释清楚,谥号为什么是文 2020-06-08 …