☆1044. ⽕星数字(20) [map映射,STL的使⽤]

阅读: 评论:0

☆1044. ⽕星数字(20) [map映射,STL的使⽤]

☆1044. ⽕星数字(20) [map映射,STL的使⽤]

1044. ⽕星数字(20) [map映射,STL的使⽤]

⽕星⼈是以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

解:因为给出的可能是数字(地球⽂)也有可能是字⺟(⽕星⽂),所以⽤字符串s保存每⼀次的输 ⼊,因为如果是⽕星⽂则会出现空格,所以⽤getline接收⼀⾏的输⼊~计算string s的⻓度len,判断 s[0]是否是数字,如果是数字,表示是地球⽂,则需要转为⽕星⽂,执⾏func1();如果不是数字,则说 明是⽕星⽂,需要转为地球⽂,执⾏func2(); func1(int t)中,传⼊的值是string转int后的结果stoi(s),因为数字最⼤不超过168,所以最多只会输出两 位⽕星⽂,如果t / 13不等于0,说明有⾼位,所以输出b[t/13];如果输出了⾼位(t/13不等于0)并且t % 13不等于0,说明有⾼位且有低位,所以此时输出空格;如果t % 13不等于0,说明有低位,此时输 出a[t % 13];注意,还有个数字0没有考虑,因为数字0取余13等于0,但是要特别输出tret,所以在 func1的最后⼀句判断中加⼀句t == 0,并将a[0]位赋值成tret即可解决0的问题~ func2()中,t1和t2⼀开始都赋值0,s1和s2⽤来分离⽕星⽂单词,因为⽕星⽂字符串只可能⼀个单词或 者两个单词,⽽且⼀个单词不会超过4,所以先将⼀个单词的赋值给s1,即s1 = s.substr(0, 3);如果len > 4,就将剩下的⼀个单词赋值给s2,即s2 = s.substr(4, 3);然后下标j从1到12遍历a和b两个数组,如果 a数组中有和s1或者s2相等的,说明低位等于j,则将j赋值给t2;如果b数组中有和s1相等的(b数组不 会和s2相等,因为如果有两个单词,s2只可能是低位),说明⾼位有值,将j赋值给t1,最后输出t1 * 13 + t2即可~

#include <cstdio>
#include <cstring>
#include <iostream>
#include <sstream>
#include <cmath>
#include <algorithm>
#include <string>
#include <stack>
#include <queue>
#include <vector>
#include <map>
using namespace std;string a[13] = { "tret", "jan", "feb", "mar", "apr", "may", "jun",
"jly", "aug", "sep", "oct", "nov", "dec" }; //低位string b[13] = { "####", "tam", "hel", "maa", "huh", "tou", "kes",
"hei", "elo", "syy", "lok", "mer", "jou" }; //高位string s;
int len;
void func1(int t) {if (t / 13 != 0) cout << b[t / 13];if ((t / 13 != 0) && (t % 13 != 0))  cout << " ";if ((t % 13 != 0) || t == 0) cout << a[t % 13];
}void func2() {int t1 = 0, t2 = 0;string s1 = s.substr(0, 3), s2; //s1是复制前面三个字符,从下标0开始,截取长度为3位if (len>4) s2 = s.substr(4, 3); //s2是:下标4开始截取长度为3位for (int j = 1; j <= 12; j++) {if (s1 == a[j] || s2 == a[j]) t2 = j;if (s1 == b[j]) t1 = j;}cout << t1 * 13 + t2;
}int main() {int n;cin >> n;getchar();for (int i = 0; i<n; i++) {getline(cin, s);len = s.length();if (s[0] >= '0'&&s[0] <= '9')func1(stoi(s)); //stoi()将字符转成数字else func2();cout << endl;}}

注释:substr()函数的用法,=%257B%2522request%255Fid%2522%253A%2522161961686916780366570271%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=161961686916780366570271&biz_id=0&utm_medium=distribute.pc_-task-blog-2~all~baidu_landing_v2~default-1-54599840.first_rank_v2_pc_rank_v29&utm_term=substr+c%2B%2B&spm=1018.2226.3001.4187

本文发布于:2024-01-28 17:26:24,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/17064339909043.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:数字   STL   map
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23