PAT 1044火星数字的代码实现及易错点分析(C语言)
2018-07-29 08:55
477 查看
题目
火星人是以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)区间内的数字 —— 或者是地球文,或者是火星文。
输出格式:
对应输入的每一行,在一行中输出翻译后的另一种语言的数字。
输入样例:
[code]4 29 5 elo nov tam
输出样例:
[code]hel mar may 115 13
实现思路:
整体思路不难,读入数据,判断哪一种数字,匹配并转换输出,主要是一些细节问题。如从例子中可以看出,火星数字并不像地球数字一样10,20这样的两位数后面加0,另外作为火星数字的匹配数组中,必须余留至少一位,存储结尾'\0',否则数据输出会连起来。
代码如下:
[code]#include<stdio.h> #include<string.h> int main() { //两个存储匹配数组务必预留结尾'\0'位,可以把高位的第一位留空,以便和数字匹配 char szD[13][5]={"tret","jan","feb","mar","apr","may","jun","jly","aug","sep","oct","nov","dec"}; char szG[13][4]={"","tam","hel","maa","huh","tou","kes","hei","elo","syy","lok","mer","jou"}; int iNum=0; scanf("%d",&iNum); getchar();//scanf和gets连用的时候,一定注意scanf后面的回车要去掉 char szData[iNum][9]; for(int i=0;i<iNum;i++) { gets(szData[i]); } int iSum=0; for(int i=0;i<iNum;i++) { iSum=0; //判断为地球数字 if(szData[i][0]>='0'&&szData[i][0]<='9') { //得到数字值 for(int j=0;j<strlen(szData[i]);j++) { iSum=iSum*10+szData[i][j]-'0'; } //分类输出 if(iSum/13!=0&&iSum%13!=0) { printf("%s %s",szG[iSum/13],szD[iSum%13]); } else if(iSum/13!=0&&iSum%13==0) { printf("%s",szG[iSum/13]); } else if(iSum/13==0) { printf("%s",szD[iSum%13]); } } else { //只有一位火星数字的情况 if(strlen(szData[i])<=4) { for(int j=0;j<13;j++) { if(strcmp(szData[i],szD[j])==0) { iSum=j; break; } else if(strcmp(szData[i],szG[j])==0) { iSum=j*13; break; } } } //两位火星数字的情况 else { for(int j=0;j<13;j++) { if(strncmp(szData[i],szG[j],3)==0)//比较前3位,即高位 { iSum+=13*j; } if(strcmp(&szData[i][4],szD[j])==0) { iSum+=j; } } } printf("%d",iSum); } if(i!=iNum-1) { printf("\n"); } } return 0; }
易错点:
1.火星文10不输出0的情况;
2.scanf和gets连用中间的回车会让第一个gets为空,最后一个漏掉;
3.strcmp和strncmp的用法。
阅读更多相关文章推荐
- PAT 1048数字加密的代码实现及错误分析(C语言)
- PAT Basic 1044. 火星数字(20)(C语言实现)
- PAT乙级1044(C语言)-火星数字(20)
- PAT 1015德才论的代码实现及错误分析(C语言)
- 1044. 火星数字(20)-浙大PAT乙级真题java实现
- PAT 1075链表元素的分类代码实现及错误分析(C语言)
- PAT 1052卖个萌的代码实现及错误分析(C语言)
- PAT 1050螺旋矩阵的代码实现及错误分析(C语言)
- PAT 1084外观数列的代码实现及错误分析(C语言)
- PAT 万绿丛中一点红的代码实现及错误分析附带PAT内存限制一点想法(C语言)
- PAT 1067试密码的代码实现及错误分析(C语言)
- PAT1078字符串压缩与解压的代码实现及错误分析(C语言)
- PAT 1079延迟的回文数的代码实现及错误分析(C语言)
- PAT 1073多选题常用计分法的代码实现及错误分析(C语言)
- PAT (Basic Level) Practise (中文)1044. 火星数字(20) C语言
- PAT 1045快速排序的代码实现及错误分析(C语言)
- PAT 1051复数乘法的代码实现及错误分析(C语言)
- PAT 1055集体照的代码实现及错误分析(C语言)
- PAT 1080MOOC期终成绩的代码实现及错误分析(C语言)
- PAT 1054求平均值的代码实现及错误分析(C语言)