pat乙级 1044 火星数字 (20 分)

博客围绕地球和火星数字互译问题展开,给出输入输出格式及样例。指出这是进制转换题型,本质是字符串和数字转化问题,输入统一按字符串处理。还介绍根据输入区分字符或数字的处理思路,并给出AC代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原题链接:https://pintia.cn/problem-sets/994805260223102976/problems/994805279328157696

火星人是以 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
13

本题思路:这类进制转换题型是各种比赛非常喜欢考查的一类题目。本质其实就是字符串和数字之间进行转化处理的问题。因为涉及到数字和字符,所以输入类型统一按字符串进行处理。
1.根据字符串str中的str[0]区分是当前输入是字符or数字;如果是数字,先将字符串转化成数字,然后对13做除法(/)和取余(%),特别注意对13这个数的处理。主要是这三行代码判断输出:decs数组保存的是对13做除法后的进位,而mars数组保存的是对13取余后的余数

if(value/13)//有高位 
	printf("%s",decs[value/13]);
if((value/13)&&(value%13))
	printf(" "); 
if(value%13||value==0)
	printf("%s",mars[value%13]);

2.如果是字符串(火星文),则需要转化成对应的数字。这时分为对空格前后的两个字符串进行处理;

本题AC代码如下:关键之处均加注释


/*
	火星数字 
*/ 

#include <bits/stdc++.h>
using namespace std;
//余数 
char mars[][10] = {"tret","jan","feb","mar","apr","may","jun","jly","aug","sep","oct","nov","dec"}; 
//进位 
char decs[][10] = {"","tam","hel","maa","huh","tou","kes","hei","elo","syy","lok","mer","jou"};

int main()
{
	int n;
	char str[20];
	char str1[20];
	int i,j;
	while(scanf("%d",&n) == 1)
	{
		getchar();	//吸收回车符 
		int value = 0;
		for(i=0;i<n;i++)
		{
			value = 0;
			j = 0;
			memset(str,0,sizeof(str));
			memset(str1,0,sizeof(str1));
			//以回车符结束输入 
			while((str[j++]=getchar())!='\n');
			str[j-1] = '\0';//把末尾的\n去掉 
			//printf("len=%d\n",strlen(str));
			if(str[0]>='0'&&str[0]<='9')
			{//数字 
				for(j=0;j<strlen(str);j++)
				{//将字符串转化成数字 
					value = value*10+str[j]-'0';		
				}
				if(value/13)//有高位 
					printf("%s",decs[value/13]);
				if((value/13)&&(value%13))
					printf(" "); 
				if(value%13||value==0)
					printf("%s",mars[value%13]);			
			}
			else if(str[0]>='a'&&str[0]<='z')
			{//字母  
				int len = strlen(str); 
				if(len>4)
				{
					//将空格后面的复制到str1数组中 
					for(j=4;j<len;j++)
						str1[j-4] = str[j];
					str[3] = '\0'; 
					for(j=1;j<13;j++)
					{
						if(strcmp(decs[j],str)==0)
						{
							break;
						}
					}
					value = value*13+j;
					for(j=0;j<13;j++)
					{
						if(strcmp(mars[j],str1)==0)
						{
							break;
						}				
					}
					value = value*13+j; 
					printf("%d",value);
				} 
				else
				{
					for(j=1;j<13;j++)
					{
						if(strcmp(decs[j],str)==0)
						{
							break;
						}
					}
					if(j<13)
					{
						printf("%d",j*13);
					}						
					else
					{
						for(j=0;j<13;j++)
						{
							if(strcmp(mars[j],str)==0)
							{
								break;
							}
						}
						printf("%d",j);
					}
				}				
			} 
			printf("\n");
		}		
	}
	return 0;	
}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值