标签:std 10 int 云课 蓝桥 num 年龄 include
题目描述
本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。
美国数学家维纳智力早熟,11 岁就上了大学。他曾在 1935 ~ 1936 年应邀来中国清华大学讲学。
一次,他参加某个重要会议,年轻的脸孔引人注目。于是有人询问他的年龄,他回答说:
“我年龄的立方是个 4 位数。我年龄的 4 次方是个 6 位数。这 10 个数字正好包含了从 0 到 9 这 10 个数字,每个都恰好出现 1 次。”
请你推算一下,他当时到底有多年轻。
运行限制
- 最大运行时间:1s
- 最大运行内存: 128M
法一:穷举寻找
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
for(int i = 11 ; i <= 100 ; i ++){
int n = pow(i , 4);
int m = pow(i , 3);
cout << n << m << endl;
}
return 0;
}
然后找符合条件的写出答案即可,因为比赛中的填空只需要写出答案就行。
法二:正常思路得出
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
int num[10];
bool panduan(int num[10])
{
sort(num , num + 9);
for(int i = 1 ; i <= 9 ; i ++)
{
if(num[i - 1] == num[i])
{
return false;
}
}
return true;
}
int main()
{
int m = 0;
for(int i = 10 ; i < 100 ; i ++)
{
int age = pow(i , 3);
int age1 = pow(i , 4);
num[0] = age1 % 10;
num[1] = age1 / 10 % 10;
num[2] = age1 / 100 % 10;
num[3] = age1 / 1000 % 10;
num[4] = age1 / 10000 % 10;
num[5] = age1 / 100000 % 10;
num[6] = age % 10;
num[7] = age / 10 % 10;
num[8] = age / 100 % 10;
num[9] = age / 1000 % 10;
if(panduan(num))
{
cout << i << endl;
break;
}
}
return 0;
}
标签:std,10,int,云课,蓝桥,num,年龄,include 来源: https://blog.csdn.net/weixin_52030368/article/details/123307231
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。