题目描述
本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。
美国数学家维纳智力早熟,11 岁就上了大学。他曾在 1935 ~ 1936 年应邀来中国清华大学讲学。
一次,他参加某个重要会议,年轻的脸孔引人注目。于是有人询问他的年龄,他回答说:
“我年龄的立方是个 4 位数。我年龄的 4 次方是个 6 位数。这 10 个数字正好包含了从 0到 9 这 10 个数字,每个都恰好出现 1 次。”
请你推算一下,他当时到底有多年轻。
运行限制
- 最大运行时间:1s
- 最大运行内存: 128M
#include <bits/stdc++.h>
using namespace std;
set<int> s;//引用STL中的set容器解法:
//主要思路:set容器能够使输入的每一个元素按照顺序排列并且不重复
void insert(int num){
while(num){
s.insert(num%10);//在insert函数中将每次的个位数压入容器s中
num/=10;
}
}
int main()
{
int y=11;//从11岁开始
int a,b;//a和b分别是需要检验判断的两个数
while(y++){
s.clear();//每一次年龄增加后都清空s的容器内的值
a=pow(y,3);
b=pow(y,4);
insert(a);//进入insert这个函数中
insert(b);
if(s.size()==10)//如果容器s中元素个数达到10就说明就满足条件得到结果就是它的年龄
{
cout<<y;
break;
}
}
return 0;
}
#include <bits/stdc++.h>
using namespace std;
int main()
{
int i;
int a[10]={0,1,2,3,4,5,6,7,8,9};
do
{
for(i=11;i<=30;i++)
{
if((i*i*i==a[0]*1000+a[1]*100+a[2]*10+a[3])&&(i*i*i*i==a[4]*100000+a[5]*10000+a[6]*1000+a[7]*100+a[8]*10+a[9]))
{
cout<<i<<endl;
}
}
}while(next_permutation(a,a+10));
return 0;
}