PAT-ADVANCED1027——Colors in Mars
我的PAT-ADVANCED代码仓:https://github.com/617076674/PAT-ADVANCED
原题链接:https://pintia.cn/problem-sets/994805342720868352/problems/994805470349344768
题目描述:
题目翻译:
1027 火星颜色
火星上的人们以与地球人类似的方式代表他们计算机中的颜色。也就是说,颜色由6位数字表示,其中前2位数字表示红色,中间2位数字表示绿色,最后2位数字表示蓝色。唯一的区别是它们使用13进制(0-9和A-C)而不是16进制。现在给出三个十进制数字(每个在0和168之间)的颜色,你需要输出它们的火星RGB值。
输入格式:
每个输入文件包含一个测试用例。每个测试用例在一行中给出3个代表颜色的十进制数字。
输出格式:
对每个测试用例,你需要按以下格式输出火星上的RGB值:首先输出#,然后是6个字符,其中所有英文字符必须是大写的。如果单个颜色只有1位数长,则必须在其左侧打印0。
输入样例:
15 43 71
输出样例:
#123456
知识点:进制转换
思路:将每个数字转换成13进制数字即可
时间复杂度和空间复杂度的分析对本题意义不大。
C++代码:
#include<iostream>
#include<utility>
using namespace std;
char Mars[13] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C'};
pair<char, char> change(int num);
int main(){
int Red, Green, Blue;
scanf("%d %d %d", &Red, &Green, &Blue);
pair<char, char> RedPair = change(Red);
pair<char, char> GreenPair = change(Green);
pair<char, char> BluePair = change(Blue);
printf("#%c%c%c%c%c%c\n", RedPair.first, RedPair.second, GreenPair.first, GreenPair.second, BluePair.first, BluePair.second);
return 0;
}
pair<char, char> change(int num){
pair<char, char> result;
result.first = Mars[num / 13];
result.second = Mars[num % 13];
return result;
}
C++解题报告: