博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
蓝桥杯真题 18省Ca4-第几个幸运数 问题描述 到x星球旅行的游客都被发给一个整数,作为游客编号。 x星的国王有个怪癖,他只喜欢数字3,5和7。 国王规定,游客的编号如果只含有因子:3,5,
阅读量:3962 次
发布时间:2019-05-24

本文共 856 字,大约阅读时间需要 2 分钟。

问题描述

到x星球旅行的游客都被发给一个整数,作为游客编号。

x星的国王有个怪癖,他只喜欢数字3,5和7。
国王规定,游客的编号如果只含有因子:3,5,7,就可以获得一份奖品。

我们来看前10个幸运数字是:

3 5 7 9 15 21 25 27 35 45
因而第11个幸运数字是:49

小明领到了一个幸运数字 59084709587505,他去领奖的时候,人家要求他准确地说出这是第几个幸运数字,否则领不到奖品。

请你帮小明计算一下,59084709587505是第几个幸运数字。

需要输出的是一个整数,请不要填写任何多余内容。

输入

没有输入

输出

一个整数。

提示

把答案放在输出语句中输出,例如C/C++语言可以用printf或cout。

思路:

每个幸运数一定满足3^i * 5^j * 7^k ,只要找出在59084709587505之前有多少个数满足3^i * 5^j * 7^k 那么就能得出这是第几个幸运数字,所以可以用循环将小于59084709587505并满足3^i * 5^j * 7^k的数找出,可以用三个循环嵌套分别对 i , j , k 赋值,并进行判断此时结果是否符合幸运数字。

其中要特别注意:i,j,k都为0时不符合要求,要减去1。

代码:

#include 
#include
int main (){
int i,j,k; int num=0; long long x = 59084709587505; for(i=0; pow(3,i)<=x; i++) for(j=0; pow(5,j)<=x; j++) for(k=0; pow(7,k)<=x; k++) {
if(pow(3,i)*pow(5,j)*pow(7,k)<=x) {
num++; } } printf("%d",num-1);//其中i,j,k都为0时不符合要求,要减去1 return 0;}

转载地址:http://jsrzi.baihongyu.com/

你可能感兴趣的文章
软件生存期模型
查看>>
制定计划(问题的定义,可行性研究)
查看>>
需求分析
查看>>
软件设计
查看>>
程序编码
查看>>
软件测试
查看>>
软件维护
查看>>
软件项目管理
查看>>
面向过程的分析方法
查看>>
软件设计基础
查看>>
UML的基本结构
查看>>
UML中几种类间关系:继承、实现、依赖、关联、聚合、组合的联系与区别
查看>>
用例图(UseCase Diagram)—UML图(一)
查看>>
类图(Class diagram)—UML图(二)
查看>>
活动图(Activity Diagram)—UML图(四)
查看>>
C#方法重载(overload)方法重写(override)隐藏(new)
查看>>
CSS+DIV练手-公司
查看>>
CSS+DIV练手—鲜花展
查看>>
深入浅出JavaScript(1)—ECMAScript
查看>>
深入浅出JavaScript(2)—ECMAScript
查看>>