PAT-ADVANCED1027——Colors in Mars

版权声明:我的GitHub:https://github.com/617076674。真诚求星! https://blog.csdn.net/qq_41231926/article/details/83956027

我的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++解题报告:

猜你喜欢

转载自blog.csdn.net/qq_41231926/article/details/83956027