07:玛雅历

来源:http://noi.openjudge.cn/ch0113/07/

POJ 1008

总时间限制:1000ms  内存限制:65536kB
描述

上周末,M.A. Ya教授对古老的玛雅有了一个重大发现。从一个古老的节绳(玛雅人用于记事的工具)中,教授发现玛雅人使用了一个一年有365天的叫做Haab的历法。这个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,它只有5天,用0到4表示。玛雅人认为这个日期最少的月份是不吉利的,在这个月法庭不开庭,人们不从事交易,甚至没有人打扫屋中的地板。

因为宗教的原因,玛雅人还使用了另一个历法,在这个历法中年被称为Tzolkin(holly年),一年被分成13个不同的时期,每个时期有20天,每一天用一个数字和一个单词相组合的形式来表示。使用的数字是1~13,使用的单词共有20个,它们分别是:imix,
ik, akbal, kan, chicchan, cimi, manik, lamat, muluk, ok, chuen, eb,
ben, ix, mem, cib, caban, eznab, canac,
ahau。注意:年中的每一天都有着明确唯一的描述,比如,在一年的开始,日期如下描述: 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 ……也就是说数字和单词各自独立循环使用。

Haab历和Tzolkin历中的年都用数字0,1,……表示,数字0表示世界的开始。所以第一天被表示成:
Haab: 0. pop 0
Tzolkin: 1 imix 0
请帮助M.A. Ya教授写一个程序可以把Haab历转化成Tzolkin历。

输入
Haab历中的数据由如下的方式表示:
日期. 月份 年数

输入中的第一行表示要转化的Haab历日期的数据量。下面的每一行表示一个日期,年数小于5000。

输出
Tzolkin历中的数据由如下的方式表示:
天数字 天名称 年数

第一行表示输出的日期数量。下面的每一行表示一个输入数据中对应的Tzolkin历中的日期。

样例输入
3
10. zac 0
0. pop 0
10. zac 1995
样例输出
3
3 chuen 0
1 imix 0
9 cimi 2801

思路分析:

1、先将输入的日期转换为距离日期开始点的天数
    temp=findHaabMonth(HaabMonth);//根据输入的月份的名字返回该月份的序号(1~19)
    sum=HaabYear*365+(temp-1)*20+HaabDay+1;
    //这个地方temp-1是表示要计算第temp个月之前的temp-1个月的天数;
    //HaabDay+1是因为输入的日期编号是从0开始的。
2、然后根据sum计算对应的Tzolkin历的年、天数字、天名称(过程参考代码注释)

注意这组特殊数据:
4. uayet 259
正解是13 ahau 364
而不是13 ahau 365
也就是说,假如给的日期对应到Tzolkin历某一年的最后一天,那么总天数sum/260求得的年份值应当减掉1.
(因为虽然总共经历了sum/260年,但是日历表示中,当天是上一年最后一天,故年份值sum/260需要减掉1.)

详细代码:

 1 #include <stdio.h>
 2 int findHaabMonth(char haabMonth[]);//根据输入的月份的名字返回该月份的序号(1~19)
 3 char HaabMonthNameDic[20][30]=
 4 {
 5      "pop","no","zip","zotz","tzec","xul","yoxkin","mol","chen","yax","zac","ceh",
 6      "mac","kankin","muan","pax","koyab","cumhu","uayet"
 7 };
 8 char TzolkinDayNameDic[20][30]=
 9 {
10     "imix", "ik", "akbal", "kan", "chicchan", "cimi", "manik", "lamat", "muluk", "ok",
11      "chuen", "eb", "ben", "ix", "mem", "cib", "caban", "eznab", "canac", "ahau"
12 };
13 int main()
14 {
15     int n,i;
16     int HaabDay; char HaabMonth[30]; int HaabYear;
17     int sum;
18     int TzolkinDayNumber; int TzolkinDayNameIndex; int TzolkinYear;
19     int temp;
20
21     scanf("%d",&n);
22     printf("%d\n",n);
23     for(i=0;i<n;i++)
24     {
25         sum=0;
26         scanf("%d. %s %d",&HaabDay,HaabMonth,&HaabYear);
27
28         //先将输入的日期转换为距离日期开始点的天数
29         temp=findHaabMonth(HaabMonth);//根据输入的月份的名字返回该月份的序号(1~19)
30         sum=HaabYear*365+(temp-1)*20+HaabDay+1;
31         //这个地方temp-1是表示要计算第temp个月之前的temp-1个月的天数;
32         //HaabDay+1是因为输入的日期编号是从0开始的。
33
34
35         //然后根据sum计算对应的Tzolkin历的年、天数字、天名称
36         TzolkinYear=sum/260;//(Tzolkin年每一年是260天)
37
38         TzolkinDayNumber=sum%13;//余数sum%13的范围是0~12
39         if(TzolkinDayNumber==0) TzolkinDayNumber=13;//Tzolkin历的天数字的编号是1~13。
40         //余数为1~12可以直接对应编号1~12,但是余数0应该对应到编号13(就是上一个数字周期1到13的那个13)
41
42         TzolkinDayNameIndex=sum%20;//余数sum%20范围是0~19
43         if(TzolkinDayNameIndex==0) TzolkinDayNameIndex=20;//Tzolkin历的天名称在数组TzolkinDayNameDic[][]中的行编号是0~19
44         //余数0应该对应到上一个数字周期1~20当中的那个20.
45
46         if(TzolkinDayNumber==13&&TzolkinDayNameIndex==20) TzolkinYear--;
47         //假如给的日期对应到Tzolkin历某一年的最后一天,那么总天数sum/260求得的年份值应当减掉1.
48
49         printf("%d %s %d\n",TzolkinDayNumber,TzolkinDayNameDic[TzolkinDayNameIndex-1],TzolkinYear);
50         //printf("%d %d %d %d\n",sum,TzolkinDayNumber,TzolkinDayNameIndex,TzolkinYear);
51     }
52     return 0;
53 }
54 int findHaabMonth(char haabMonth[])//根据输入的月份的名字返回该月份的序号(1~19)
55 {
56     int i;
57     for(i=0;i<19;i++)
58     {
59         if(strcmp(haabMonth,HaabMonthNameDic[i])==0) break;
60     }
61     return i+1;
62 }
时间: 2024-10-13 08:33:11

07:玛雅历的相关文章

整理小朋友在noi.openjudge上的作业(1)

NOI(题库正在建设中,做题纪录有可能会被删除,请注意) 第一章的统计放前面 1 编程基础之输入输出 10 0 0% 最基础有空补刷 2 编程基础之变量定义.赋值及转换 10 0 0% 最基础有空补刷 3 编程基础之算术表达式与顺序执行 20 0 0% 最基础有空补刷 4 编程基础之逻辑表达式与条件分支 21 0 0% 最基础有空补刷 5 编程基础之循环控制 45 10 22% 最基础有空补刷 6 编程基础之一维数组 15 5 33% 最基础有空补刷 7 编程基础之字符串 35 0 0% 有必要

百度房间卡是否可骄傲是快乐积分拉斯科

http://www.ebay.com/cln/ycn6646/-/167568259015/2015.02.07 http://www.ebay.com/cln/gon-n31/-/167197496017/2015.02.07 http://www.ebay.com/cln/hu_d027/-/167453250013/2015.02.07 http://www.ebay.com/cln/ywa2962/-/167301832012/2015.02.07 http://www.ebay.co

笔试算法题(07):还原后序遍历数组 &amp; 半翻转英文句段

出题:输入一个整数数组,判断该数组是否符合一个二元查找树的后序遍历(给定整数数组,判定其是否满足某二元查找树的后序遍历): 分析:利用后序遍历对应到二元查找树的性质(序列最后一个元素必定是根节点,从左向右第一个比根节点大的元素开始直到根节点之前的所有元素必定在右子树,之前的所有元素必定在左子树): 解题: 1 bool PostOrderCheck(int *array, int i, int j) { 2 /** 3 * 如快速排序一样,解决小子文件 4 * */ 5 if(j-i+1 ==

java进阶07 线程的让步与阻塞与同步

前面介绍了线程的一些基本知识,现在来说下线程的让步,阻塞,和同步 先说说让步 所谓让步,就是让调用者的线程暂停,让其他线程重新竞争CPU,包括调用者. 先看看代码 package Thread; public class ThreadYield { public static void main(String[] args){ MyThread5 rthread=new MyThread5(); Thread thread1=new Thread(rthread); Thread thread2

P1807 最长路_NOI导刊2010提高(07)

P1807 最长路_NOI导刊2010提高(07) 题目描述 设G为有n个顶点的有向无环图,G中各顶点的编号为1到n,且当为G中的一条边时有i < j.设w(i,j)为边的长度,请设计算法,计算图G中<1,n>间的最长路径. 输入输出格式 输入格式: 输入文件longest.in的第一行有两个整数n和m,表示有n个顶点和m条边,接下来m行中每行输入3个整数a,b,v(表示从a点到b点有条边,边的长度为v). 输出格式: 输出文件longest.out,一个整数,即1到n之间的最长路径.如

07:合影效果

07:合影效果 查看 提交 统计 提问 总时间限制:  1000ms 内存限制:  65536kB 描述 小云和朋友们去爬香山,为美丽的景色所陶醉,想合影留念.如果他们站成一排,男生全部在左(从拍照者的角度),并按照从矮到高的顺序从左到右排,女生全部在右,并按照从高到矮的顺序从左到右排,请问他们合影的效果是什么样的(所有人的身高都不同)? 输入 第一行是人数n(2 <= n <= 40,且至少有1个男生和1个女生).后面紧跟n行,每行输入一个人的性别(男male或女female)和身高(浮点数

U-BOOT-2016.07移植 (第一篇) 初步分析

U-BOOT-2016.07移植 (第一篇) 初步分析 目录 U-BOOT-201607移植 第一篇 初步分析 目录 编译和移植环境 更新交叉编译工具 1 下载arm-linux-gcc 443 2 安装arm-linux-gcc 443 安装环境Ubuntu 910 下载u-boot-201607并解压 分析顶层Makefile 1 找出目标依赖关系 2 总结 初次编译u-boot 1 配置 2 编译 分析u-boot启动流程 1 分析startS 2 分析crt0S 3 总结 1. 编译和移

【博客美化】07.添加打赏按钮

博客园美化相关文章目录: [博客美化]01.推荐和反对炫酷样式 [博客美化]02.公告栏显示个性化时间 [博客美化]03.分享按钮 [博客美化]04.自定义地址栏logo [博客美化]05.添加GitHub链接 [博客美化]06.添加QQ交谈链接 [博客美化]07.添加打赏按钮 1.添加打赏按钮 进入自己的博客园->设置,将以下html代码添加到“页首Html代码” <!--打赏 Start--> <script> window.tctipConfig = { staticP

个人冲刺07

个人冲刺07 一.任务:继续实现注册界面,完成注册时短信验证码回复的功能 二.预计时间:2天. 三.实际花费时间:5天(逾期3天). 四.自问自答三个问题: (1)昨天做了什么? 编程,一直在解决短信验证码回复功能的问题 (2)今天要做什么? 编程,继续解决短信验证码回复功能的问题 (3)遇到了什么问题 最终没有实现短信验证码回复功能 四.个人燃尽图