PAT甲级-1100 Mars Numbers(包括所有测试用例)

这道题的测试用例给我整急眼了。反复实验总结如下。
1044 火星数字(20)(20 分)

火星人是以13进制计数的:

地球人的0被火星人称为tret。
地球人数字1到12的火星文分别为:jan, feb, mar, apr, may, jun, jly, aug, sep, oct, nov, dec。
火星人将进位以后的12个高位数字分别称为:tam, hel, maa, huh, tou, kes, hei, elo, syy, lok, mer, jou。

例如地球人的数字“29”翻译成火星文就是“hel mar”;而火星文“elo nov”对应地球数字“115”。为了方便交流,请你编写程序实现地球和火星数字之间的互译。

输入格式:

输入第一行给出一个正整数N(<100),随后N行,每行给出一个[0, 169)区间内的数字 —— 或者是地球文,或者是火星文。

输出格式:

对应输入的每一行,在一行中输出翻译后的另一种语言的数字。

输入样例:

4
29
5
elo nov
tam

输出样例:

hel mar
may
115

总结:
首先测试用例重点注意火星文转化为地球十进制数。经反复实验,以下火星文通过就应该可以AC。
PAT甲级-1100 Mars Numbers(包括所有测试用例)_第1张图片
除此之外应该注意细节。
1.cin遇见空格停止输入。getline(cin,str)遇见回车停止输入,可以读入空格,但是此题注意想要进入循环,需要用getchar()先吃一个回车。否则少一次循环。很重要。
2.cstring中的substr函数。很实用,提取字符串中某一部分。
3.实现火星文到地球文,本题可以不用map映射。直接遍历字符串数组对比。

    s3=s.substr(0,3);//字符串前一半。十位
	if(s.length()>3)
	s4=s.substr(4,3);//后一半。个位
	for(int i=0;i<13;i++)
	{
		if(s3==s2[i]) n1=i;//高位十三进制数只能在十位的位置
		if(s3==s1[i]||s4==s1[i]) n2=i;//低位十三进制数可在十位或者个位的位置
	}
	cout<<n1*13+n2<<endl;

总代码:

#include
#include
#include 
using namespace std;
string s1[13]={"tret","jan","feb","mar","apr","may","jun","jly","aug","sep","oct","nov","dec"};
string s2[13]={"tret","tam","hel","maa","huh","tou","kes","hei","elo","syy","lok","mer","jou"};

void zhuanhuan(string s)
{
	int num=0,shang=0,yushu=0;
	for(int i=0;i<s.length();i++)
	{
		num=num*10+s[i]-'0';
	}
	if(num<13)
	cout<<s1[num]<<endl;
	else
	{
		shang=num/13;
		yushu=num%13;
		if(yushu!=0) 
		cout<<s2[shang]<<" "<<s1[yushu]<<endl;
		else
		cout<<s2[shang]<<endl;	
	}
} 

void zhuanhuan2(string s)
{
	int n1=0,n2=0;//记得初始化!!
	string s3,s4;
	s3=s.substr(0,3);
	if(s.length()>3)
	s4=s.substr(4,3);
	for(int i=0;i<13;i++)
	{
		if(s3==s2[i]) n1=i;//
		if(s3==s1[i]||s4==s1[i]) n2=i;
	}
	cout<<n1*13+n2<<endl;
}
 
int main()
{
	int n;
	cin>>n;
	getchar();//吃一个回车 
	string s;
	for(int i=0;i<n;i++)
	{
		getline(cin,s);//遇见回车,结束输入 
		if(s[0]<='9'&&s[0]>='0')//注意等号
		zhuanhuan(s);
		else
		zhuanhuan2(s);
	}
}

你可能感兴趣的:(PAT甲级)