问题1916--【CSPS2020提高组】儒略日

1916: 【CSPS2020提高组】儒略日

[命题人 : ]
时间限制 : 1.000 sec  内存限制 : 128 MB

题目描述

为了简便计算,天文学家们使用儒略日(Julianday)来表达时间。所谓儒略日,其定义为从公元前4713年1月1日正午12点到此后某一时刻间所经过的天数,不满一天者用小数表达。若利用这一天文学历法,则每一个时刻都将被均匀的映射到数轴上,从而得以很方便的计算它们的差值。

现在,给定一个不含小数部分的儒略日,请你帮忙计算出该儒略日(一定是某一天的中午12点)所对应的公历日期。

我们现行的公历为格里高利历(Gregoriancalendar),它是在公元1582年由教皇格里高利十三世在原有的儒略历(Juliancalendar)的基础上修改得到的(注:儒略历与儒略日并无直接关系)。具体而言,现行的公历日期按照以下规则计算:

1.公元1582年10月15日(含)以后:适用格里高利历,每年一月31天、二月28天或29天、三月31天、四月30天、五月31天、六月30天、七月31天、八月31天、九月30天、十月31天、十一月30天、十二月31天。其中,闰年的二月为29天,平年为28天。当年份是400的倍数,或日期年份是4的倍数但不是100的倍数时,该年为闰年。
2.公元1582年10月5日(含)至10月14日(含):不存在,这些日期被删除,该年10月4日之后为10月15日。
3.公元1582年10月4日(含)以前:适用儒略历,每月天数与格里高利历相同,但只要年份是4的倍数就是闰年。
4.尽管儒略历于公元前45年才开始实行,且初期经过若干次调整,但今天人类习惯于按照儒略历最终的规则反推一切1582年10月4日之前的时间。注意,公元零年并不存在,即公元前1年的下一年是公元1年。因此公元前1年、前5年、前9年、前13年……以此类推的年份应视为闰年。

输入

第一行一个整数Q,表示询问的组数。
接下来Q行,每行一个非负整数ri,表示一个儒略日。

输出

对于每一个儒略日ri,输出一行表示日期的字符串si。共计Q行。si的格式如下:

1.若年份为公元后,输出格式为Day Month Year。其中日(Day)、月(Month)、年(Year)均不含前导零,中间用一个空格隔开。例如:公元2020年11月7日正午12点,输出为7 11 2020。
2.若年份为公元前,输出格式为Day Month Year BC。其中年(Year)输出该年份的数值,其余与公元后相同。例如:公元前841年2月1日正午12点,输出为1 2 841 BC。

样例输入 Copy

3
10
100
1000

样例输出 Copy

11 1 4713 BC
10 4 4713 BC
27 9 4711 BC

提示

输入#2
3
2000000
3000000
4000000
输出#2
149763
1583501
1276239

说明/提示


【数据范围】

测试点编号 Q =Q= r_i \leri
11 10001000 365365
22 10001000 10^4104
33 10001000 10^5105
44 1000010000 3\times 10^53×105
55 1000010000 2.5\times 10^62.5×106
66 10^5105 2.5\times 10^62.5×106
77 10^5105 5\times 10^65×106
88 10^5105 10^7107
99 10^5105 10^9109
1010 10^5105 年份答案不超过 10^9109

来源/分类