题目描述
古代中国使用天干地支来记录当前的年份。
天干一共有十个,分别为:甲(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)。
将天干和地支连起来,就组成了一个天干地支的年份,例如:甲子。
2020 年是庚子年。
每过一年,天干和地支都会移动到下一个。例如
2021 年是辛丑年。
每过 60 年,天干会循环 6 轮,地支会循环 5 轮,所以天干地支纪年每 60 年轮回一次。例如 1900 年,1960 年,2020 年都是庚子年。
给定一个公元纪年的年份,请输出这一年的天干地支年份。
输入描述
输入一行包含一个正整数,表示公元年份。
其中有 ,输入的公元年份为不超过
9999
9999 的正整数。
输出描述
输入一行包含一个正整数,表示公元年份。
其实这种没有考察算法的题,挺好做的,只需要模拟出题目给的过程就可以解出来了。以2020为起始点,大于2020的年份,向后模拟;小于2020的年份向前模拟
#include <iostream>
#include<math.h>
using namespace std;
int main()
{
// 请在此输入您的代码
string a[11]={" ","jia","yi","bing","ding","wu","ji","geng","xin","ren","gui"};
string b[13]={" ","zi","chou","yin","mao","chen","si","wu","wei","shen","you","xu","hai"};
int m1=7,m2=1;
int n,m;
cin>>n;
if(n>=2020)//这是大于2020的年份
{
m=n-2020;//m代表相差的年份
for(int i=0;i<m;i++)//每过一年两个数组下标都往后移一位
{
m1++;
if(m1>10)
m1=1;
m2++;
if(m2>12)
m2=1;
}
cout<<a[m1]<<b[m2];
return 0;
}
else //这是小于2020的年份
{
m=2020-n;//m代表相差的年份
for(int i=0;i<m;i++)//每过一年两个数组下标都往前移一位
{
m1--;
if(m1==0)
m1=10;
m2--;
if(m2==0)
m2=12;
}
cout<<a[m1]<<b[m2];
return 0;
}
return 0;
}