1. 问题描述
用户登录
https://www.lanqiao.cn/problems/1029/learning/?page=1&first_category_id=1&sort=difficulty&asc=1&tags=%E6%A8%A1%E6%8B%9F
古代中国使用天干地支来记录当前的年份。
天干一共有十个,分别为:甲(jiǎ)、乙(yǐ)、丙(bǐng)、丁(dīng)、戊(wù)、己(jǐ)、庚(gēng)、辛(xīn)、壬(rén)、癸(guǐ)。
地支一共有十二个,分别为:子(zǐ)、丑(chǒu)、寅(yín)、卯(mǎo)、辰(chén)、巳(sì)、午(wǔ)、未(wèi)、申(shēn)、酉(yǒu)、戌(xū)、 亥(hài)。
将天干和地支连起来,就组成了一个天干地支的年份,例如:甲子。
20202020 年是庚子年。
每过一年,天干和地支都会移动到下一个。例如 20212021 年是辛丑年。
每过 6060 年,天干会循环 66 轮,地支会循环 55 轮,所以天干地支纪年每 6060 年轮回一次。例如 19001900 年,19601960 年,20202020 年都是庚子年。
给定一个公元纪年的年份,请输出这一年的天干地支年份。
输入格式:
输入一行包含一个正整数,表示公元年份。
其中有 ,输入的公元年份为不超过 99999999 的正整数。
输出格式:
输入一行包含一个正整数,表示公元年份。
输入输出样例:
输入
2020
输出
gengzi
2.算法分析和描述
(1)创建两个二维数组,分别存储天干和地支
(2)输入年份n,并以已知的“2020年为庚子年“为基准
(3)计算n年份与2020的差距
(4)由于60年一个轮回,所以n加减整数倍的60不会改变n年份的天干地支,利用这个得到n年份与2020年的最小正差距
(5)由于天干以10个为周期,利用(n+6)%10可以得到n年份天干对应的数组索引,同样由于地支以12个为周期,利用(n+0)%12可以得到n年份地支的数组索引
3.代码实现
#include <iostream>
using namespace std;
int main()
{
char tiangan[10][10]={"jia","yi","bing","ding","wu","ji","geng","xin","ren","gui"};
char dizhi[12][5]={"zi","chou","yin","mou","chen","si","wu","wei","shen","you","xu","hai" };
int n;
cin>>n;
n-=2020; //2020为基准
while(n<0)
{
n+=60; //60一个轮回
}
cout<<tiangan[(n+6)%10]<<dizhi[(n+0)%12];
return 0;
}