1027 Colors in Mars (20 分)

又是一题甲级水题
看题目戳这
单纯进制转换

我写的不够简洁

一开始的代码如下

#include<bits/stdc++.h>
using namespace std;
char aa[100],ab[100],ac[100];
char z(int x){
	if(x<10){
		return x+'0';
	}
	if(x==10){
		return 'A';
	}
	if(x==11){
		return 'B';
	}
	if(x==12){
		return 'C';
	}
}
int main(){
	int a,b,c,numa=0,numb=0,numc=0;
	cin>>a>>b>>c;
	cout<<"#";
	do{
		aa[numa++]=z(a%13);
		a/=13;
	}while(a);
	do{
		ab[numb++]=z(b%13);
		b/=13;
	}while(b);
	do{
		ac[numc++]=z(c%13);
		c/=13;
	}while(c);
	if(numa==1){
		printf("0%c",aa[0]);
	}else {
		printf("%c%c",aa[1],aa[0]);
	}
	if(numb==1){
		printf("0%c",ab[0]);
	}else {
		printf("%c%c",ab[1],ab[0]);
	}
	if(numc==1){
		printf("0%c",ac[0]);
	}else {
		printf("%c%c",ac[1],ac[0]);
	}
	return 0;
}

虽然说过了

但是50行代码不够简洁

以后看别人的代码再优化

猜你喜欢

转载自blog.csdn.net/weixin_43982216/article/details/89671687
今日推荐