题目
People in Mars represent the colors in their computers in a similar way as the Earth people. That is, a color is represented by a 6-digit number, where the first 2 digits are for
Red
, the middle 2 digits forGreen
, and the last 2 digits forBlue
. The only difference is that they use radix 13 (0-9 and A-C) instead of 16. Now given a color in three decimal numbers (each between 0 and 168), you are supposed to output their Mars RGB values.
输入
Each input file contains one test case which occupies a line containing the three decimal color values.
输出
For each test case you should output the Mars RGB value in the following format: first output
#
, then followed by a 6-digit number where all the English characters must be upper-cased. If a single color is only 1-digit long, you must print a0
to its left.
样例输入
15 43 71
样例输出
#123456
题意理解
给你三个10进制数字让你转换成13进制的数,这个数转换完以后必须占两个位,也就是哪怕是0也要输出00,那么我们用字符串处理即可,记得前面加个#。
代码
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
typedef unsigned long long ULL ;
typedef pair<int,int> PII;
typedef pair<double,double> PDD;
#define fx first
#define fy second
const int INF=0x3f3f3f3f;
const LL LINF=1e18;
const int N=2e5+10;
const int M=2e2+10;
const int MOD=1e9+7;
int n,m;
char turn(int x){
if(x>=0&&x<=9)return x+'0';
else return x-10+'A';
}
string radix(int x){
string res="00";
res[1]=turn(x%13);
res[0]=turn(x/13);
return res;
}
void solve(){
string ss="#";
for(int i=1;i<=3;i++){
int x;cin>>x;
ss+=radix(x);
}
cout<<ss<<endl;
}
int main(){
int T=1;
ios::sync_with_stdio(0);
cin.tie(0);cout.tie(0);
while(T--){
solve();
}
return 0;
}