题目来源:http://poj.org/problem?id=1008

题目大意:

  Maya人认为一年有365天,但他们有两种日历。一种叫做Haab,有19个月。前18个月每月20天,每个月的名字分别为:pop, no, zip, zotz, tzec, xul, yoxkin, mol, chen, yax, zac, ceh, mac, kankin, muan, pax, koyab, cumhu.每个月里的天分别用0到19编号。Haab的最后一个月叫做uayet,这个月只有五天,编号为0,1,2,3,4.Maya人认为这个月是不吉利的。

  还有一种旧的日历,叫做Tzolkin,这种日历中一年被分为13个周期,每个20天长,每天由一个数和一个名字来表示。公邮20个名字: imix, ik, akbal, kan, chicchan, cimi, manik, lamat, muluk, ok, chuen, eb, ben, ix, mem, cib, caban, eznab, canac, ahau, 和13和数字。它们都是周期性循环的。

  例如每年开始的日期表示如下:

1 imix, 2 ik, 3 akbal, 4 kan, 5 chicchan, 6 cimi, 7 manik, 8 lamat, 9 muluk, 10 ok, 11 chuen, 12 eb, 13 ben, 1 ix, 2 mem, 3 cib, 4 caban, 5 eznab, 6 canac, 7 ahau,接下来进入下一个周期,8 imix, 9 ik, 10 akbal . . .

年号被表示为0,1,...其中0是世界的开始。所以世界的第一天可以表示为:

Haab: 0. pop 0 
Tzolkin: 1 imix 0

程序的目标是将Haab日历表示的日期转换为Tzolkin日历的表示。

输入:Haab日历的输入格式为:NumberOfTheDay. Month Year

输入的第一行为一个正整数n,指明有多少个待转换的日期。后接n行,每行一个Haab日期。年数都小于5000.

输出:Tzolkin日历的输出格式为:Number NameOfTheDay Year

输出的第一行为一个正整数n,指明日期数。后接n行,每行一个转换后的日期。输出顺序与输入顺序一致。


Sample Input

3
10. zac 0
0. pop 0
10. zac 1995

Sample Output

3
3 chuen 0
1 imix 0
9 cimi 2801

本题没有什么算法上的难度,关键就是细心。小心处理数值的运算,留心不要拼错单词。我用的是C++ STL的map。

 //////////////////////////////////////////////////////////////////////////
// POJ1008 Maya Calendar
// Memory: 308K Time: 0MS
// Language: C++ Result: Accepted
////////////////////////////////////////////////////////////////////////// # include <iostream>
# include <string>
# include <map> using namespace std; class dateH {
public:
int date;
int month;
int year; dateH (int date, int month, int year) {
this->date = date;
this->month = month;
this->year = year;
}
long getCount () {
return * year + * (month - ) + date + ;
}
}; class dateT {
public:
int num;
int count;
int year; dateT(long count) {
year = (count % ) ? count / : count / - ;
int remain = count - year * ;
this -> count = (remain % ) ? (remain % ) : ;
num = (remain % ) ? (remain % ) : ;
}
int getNum () {
return num;
}
int getCount () {
return count;
}
int getYear () {
return year;
}
}; int main(void) {
int n;
cin >> n;
if (n <= ) {
return ;
}
cout << n << endl;
map<string, int> Haab;
map<int, string> Tzolkin; map<string, int>::iterator itH;
map<int, string>::iterator itT; Haab.insert(pair<string, int>("pop", ));
Haab.insert(pair<string, int>("no",));
Haab.insert(pair<string, int>("zip", ));
Haab.insert(pair<string, int>("zotz", ));
Haab.insert(pair<string, int>("tzec", ));
Haab.insert(pair<string, int>("xul", ));
Haab.insert(pair<string, int>("yoxkin", ));
Haab.insert(pair<string, int>("mol", ));
Haab.insert(pair<string, int>("chen", ));
Haab.insert(pair<string, int>("yax", ));
Haab.insert(pair<string, int>("zac", ));
Haab.insert(pair<string, int>("ceh", ));
Haab.insert(pair<string, int>("mac", ));
Haab.insert(pair<string, int>("kankin", ));
Haab.insert(pair<string, int>("muan", ));
Haab.insert(pair<string, int>("pax", ));
Haab.insert(pair<string, int>("koyab", ));
Haab.insert(pair<string, int>("cumhu", ));
Haab.insert(pair<string, int>("uayet", )); Tzolkin.insert(pair<int, string>(, "imix"));
Tzolkin.insert(pair<int, string>(, "ik"));
Tzolkin.insert(pair<int, string>(, "akbal"));
Tzolkin.insert(pair<int, string>(, "kan"));
Tzolkin.insert(pair<int, string>(, "chicchan"));
Tzolkin.insert(pair<int, string>(, "cimi"));
Tzolkin.insert(pair<int, string>(, "manik"));
Tzolkin.insert(pair<int, string>(, "lamat"));
Tzolkin.insert(pair<int, string>(, "muluk"));
Tzolkin.insert(pair<int, string>(, "ok"));
Tzolkin.insert(pair<int, string>(, "chuen"));
Tzolkin.insert(pair<int, string>(, "eb"));
Tzolkin.insert(pair<int, string>(, "ben"));
Tzolkin.insert(pair<int, string>(, "ix"));
Tzolkin.insert(pair<int, string>(, "mem"));
Tzolkin.insert(pair<int, string>(, "cib"));
Tzolkin.insert(pair<int, string>(, "caban"));
Tzolkin.insert(pair<int, string>(, "eznab"));
Tzolkin.insert(pair<int, string>(, "canac"));
Tzolkin.insert(pair<int, string>(, "ahau")); int date;
int year;
string month;
for (int i = ; i < n; i++) {
char t;
cin >> date >> t >> month >> year;
int m = (*Haab.find(month)).second;
dateH dateh (date, m, year);
long count = dateh.getCount();
dateT datet (count);
cout << datet.getNum() << " "
<< (*Tzolkin.find(datet.getCount())).second << " "
<< datet.getYear() << endl;
} system("pause");
return ;
}

POJ1008 Maya Calendar的更多相关文章

  1. 算法:POJ1008 Maya Calendar

    此题非常水,不做说明. package practice; import java.io.BufferedInputStream; import java.util.Scanner; /** * @a ...

  2. poj 1008:Maya Calendar(模拟题,玛雅日历转换)

    Maya Calendar Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 64795   Accepted: 19978 D ...

  3. POJ 1008 Maya Calendar

    链接:http://poj.org/problem?id=1008 Maya Calendar Time Limit: 1000MS   Memory Limit: 10000K Total Subm ...

  4. Maya Calendar 分类: POJ 2015-06-11 21:44 12人阅读 评论(0) 收藏

    Maya Calendar Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 70016   Accepted: 21547 D ...

  5. [POJ] #1008# Maya Calendar : 字符处理/同余问题

    一. 题目 Maya Calendar Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 74085   Accepted: 2 ...

  6. Poj OpenJudge 百练 Bailian 1008 Maya Calendar

    1.Link: http://poj.org/problem?id=1008 http://bailian.openjudge.cn/practice/1008/ 2.content: Maya Ca ...

  7. B - Maya Calendar(第二季水)

    Description During his last sabbatical, professor M. A. Ya made a surprising discovery about the old ...

  8. POJ 1008 Maya Calendar / UVA 300【日期转换/常量数组】

    Maya Calendar Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 82431 Accepted: 25319 Descr ...

  9. [POJ 1008] Maya Calendar C++解题

        Maya Calendar Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 62297   Accepted: 192 ...

随机推荐

  1. java 多线程系列基础篇(五)之线程等待与唤醒

    1.wait(), notify(), notifyAll()等方法介绍 在Object.java中,定义了wait(), notify()和notifyAll()等接口.wait()的作用是让当前线 ...

  2. nyoj42欧拉回路

    一笔画问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下 ...

  3. Ros学习service——小海龟

    rosservice 服务(services)是节点之间通讯的另一种方式.服务允许节点发送请求(request) 并获得一个响应(response) rosservice list 输出可用服务的信息 ...

  4. IO流对文件的读取操作

    /*1. 在当前项目的根目录下有一个名为“info.txt”的文件,里面存放的内容如下(可手动创建录入,不需要使用IO流): 2. 利用IO流的知识读取info.txt文件的内容, 在控制台上打印大写 ...

  5. Opengl创建机器人手臂代码示例

    /*******************************************************robot.cpp*基于opengl的机械手臂示例代码*s:机械臂逆时针旋转*S:机械臂 ...

  6. Linux tput命令

    一.简介 shell 脚本编写者往往需要能通过一种方法将输出更改为粗体,为其加下划线,实现反向突出显示等,这正是 tput 的用武之地. tput 命令将通过 terminfo 数据库对您的终端会话进 ...

  7. R: 正则表达式

    正则表达式: 例:sub("a","",c("abcd","dcba")):   [1] "bcd" ...

  8. Luogu 2467 [SDOI2010]地精部落

    挺有意思的题. 优质题解: https://www.luogu.org/blog/user55639/solution-p2467 题意为求长度为n,取值为$[1, n]$的波动序列的个数. 首先需要 ...

  9. java的import关键字的使用

    在java中如何使用Java包中自带的类呢? 方法一: 在使用时可以用Java.(包名).(方法名).(包中的类名): 例如:Java.util.Arrays.toString(某个要排序数组); 具 ...

  10. 2018年第九届蓝桥杯国赛总结(JavaB组)

    懒更,之前的删了补一个国赛总结 记yzm10的第一次国赛(赛点:首都经贸大学) 第一次就拿到了国一,运气不要太好~(同组lz学长豪取国特orz) 从省赛一路水过来,总算有了点成绩.其实最后一题有些遗憾 ...