HDU 2097 Sky数(進数変換)


Sky数
Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 20237    Accepted Submission(s): 11499
Problem Description
Skyは小さい頃から奇抜なものが好きで、しかも生まれつき数字に敏感で、偶然の機会に、彼は1つの面白い4桁の2992を発見して、この数、その10進数は表して、その4桁の数字の和は2+9+9+2=22で、その16進数BB 0、その4桁の数字の和も22で、同時にその12進数は1894を表して、その4桁の数字の和も22で、ああ、偶然ですね.Skyはこの4桁が大好きで、彼の発見のため、ここではSky数と命名しました.しかし、このような数を判断するのはちょっと面倒ですね.では、今、10進数の4桁を判断してください.Sky数ではありませんか.
Input
入力には4桁の正の整数が含まれ、0の場合は入力が終了します.
Output
nがSky数であれば「#n is a Sky Number.」を出力し、そうでなければ「#n is not a Sky Number.」を出力する.各結果は1行を占めます.注意:#nは、読み込まれたn値を表します.
Sample Input

   
   
   
   
2992 1234 0

Sample Output

   
   
   
   
2992 is a Sky Number. 1234 is not a Sky Number.

Source
2007省試合合宿チーム練習試合(2)
问题解:个数位の数を足すだけで、他の进法にならなくても判断できます.
ACコード:
#include<iostream>
#include<memory.h>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<string>
#include<cstdlib>
#include<iomanip>
#include<algorithm>
typedef long long LL;
using namespace std;
int sum(int n,int k)
{
	int s=0;
	while(n!=0)
	{
		s+=n%k;
		n/=k;
	}
	return s;
}
int main()
{
	int n;
	while(cin>>n,n)
	{
		int a,b,c;
		a=sum(n,10);  //           ,        
		b=sum(n,12);
		c=sum(n,16);
		if(a==b&&b==c&&a==c)
		cout<<n<<" is a Sky Number."<<endl;
		else
			cout<<n<<" is not a Sky Number."<<endl;
	}
	return 0;
}

進数変換の....
#include<stdio.h>
#include<string.h>
using namespace std;
int fuck1(int a)
{
    int output=0;
    while(a)
    {
        int x=a%10;
        output+=x;
        a/=10;
    }
    return output;
}
int fuck2(int a)
{
    int output=0;
    while(a)
    {
        int x=a%16;
        output+=x;
        a/=16;
    }
    return output;
}
int fuck3(int a)
{
    int output=0;
    while(a)
    {
        int x=a%12;
        output+=x;
        a/=12;
    }
    return output;
}
int main()
{
    int n;
    while(~scanf("%d",&n))
    {
        if(n==0)break;
        if(fuck1(n)==fuck2(n)&&fuck2(n)==fuck3(n))
        printf("%d is a Sky Number.
",n); else printf("%d is not a Sky Number.
",n); } }