Description

Find and list all four-digit numbers in decimal notation that have the property that the sum of its four digits equals the sum of its digits when represented in hexadecimal (base 16) notation and also equals the sum of its digits when represented in duodecimal (base 12) notation.         For example, the number 2991 has the sum of (decimal) digits 2+9+9+1 = 21. Since 2991 = 1*1728 + 8*144 + 9*12 + 3, its duodecimal representation is 1893 12, and these digits also sum up to 21. But in hexadecimal 2991 is BAF 16, and 11+10+15 = 36, so 2991 should be rejected by your program.         The next number (2992), however, has digits that sum to 22 in all three representations (including BB0 16), so 2992 should be on the listed output. (We don't want decimal numbers with fewer than four digits -- excluding leading zeroes -- so that 2992 is the first correct answer.)        
 

Input

There is no input for this problem
 
 

Output

Your output is to be 2992 and all larger four-digit numbers that satisfy the requirements (in strictly increasing order), each on a separate line with no leading or trailing blanks, ending with a new-line character. There are to be no blank lines in the output. The first few lines of the output are shown below.
 
 

Sample Input

There is no input for this problem

Sample Output

2992
2993
2994
2995
2996
2997
2998
2999
... 依旧是submit failed,以下为我写的代码
#include <iostream>
using namespace std;
int f(int n,int x)
{
int i=,j,a[],m=;
while(n!=) {
a[i++]=n%x;
n=n/x;
}
for(j=;j<i;j++)m+=a[j];
return m;
}
int main()
{
int n,i,p,q;
for(i=;i<;i++){
n=i/+i/%+i/%+i%;
p=f(i,);
q=f(i,);
if(p==n&&q==n)cout<<i<<endl;
}
system("pause");
return ;
}

以下是提交成功AC的代码

#include <iostream>
using namespace std;
int f(int n,int x)
{
int a,m=;
while(n!=) {
a=n%x;
n=n/x;
m+=a;
}
return m;
}
int main()
{
int n,i;
for(i=;i<;i++){
n=i/+i/%+i/%+i%;
if(f(i,)==n&&f(i,)==n)cout<<i<<endl;
}
//system("pause");
return ;
}

发现我写的代码似乎太啰嗦了!!!麻烦!!许多东西完全可以省略!!!!

最新文章

  1. redis 操作
  2. 深入理解GCD(一)
  3. VIm vi 使用 汇总
  4. SQL SERVER 2008安装时出现不能在控件上调用 Invoke 或 BeginInvoke错误 解决方法
  5. IO流中的文件创建并且写入读取
  6. mongo 多条件 查询
  7. log4net和一般的记录日志方法
  8. HDU 5829 Rikka with Subset
  9. Maven学习(一)-- Maven入门
  10. Centos7 配置和链接FTP
  11. Python读取excel表的数据
  12. Java知多少(54)断言详解
  13. ASP.NET Core 与 .NET Core 演变与基础概述
  14. Shell-输入密码转换为*
  15. notify notifyAll 死锁
  16. BIP_BI Pubisher的基本语法(概念)
  17. Autofac IoC容器基本实战【2】
  18. Linux命令应用大词典-第6章 文件处理
  19. springmvc使用实体參数和ServletAPI
  20. Java实现二维码生成的方法

热门文章

  1. Xcode 常用快捷键及代码自动排版
  2. UIScrollView 滑动试图
  3. Win8.1系统下安装nodeJS
  4. CDZSC_2015寒假新人(2)——数学 A
  5. imadjust函数分析一
  6. java中的IO流读取文件
  7. uploadify ,前端页面获取值,json,ajax
  8. winform 读取保存配置文件
  9. Oracle数据库之间数据同步
  10. 通过yocto给p1010rdb定制linux,并启动linux