北大oj上的一道题,哪位高手有兴趣解答下,感激不尽 http:⼀⼀poj.org⼀problem?id=1008

2025-03-30 22:44:19
推荐回答(2个)
回答1:

#include
#include
using namespace std;

int main()
{
int n,i,d,y,t,num,j;
char x;
char m[10];
char a[19][8]={"pop","no","zip","zotz","tzec","xul","yoxkin","mol","chen", "yax", "zac",
"ceh","mac","kankin","muan","pax","koyab","cumhu","uayet"};
char b[20][20]={"imix", "ik","akbal", "kan","chicchan","cimi","manik","lamat","muluk",
"ok","chuen","eb","ben","ix","mem","cib","caban","eznab","canac","ahau"};
cin >> n;
cout << n << endl;
while(n--)
{
cin>>d>>x>>m>>y;
for(i=0;i<19;i++)
if(strcmp(m,a[i])==0)
{
num=y*365+i*20+d+1;
break;
}
y=num/260;
t=num%260;
if(t==0) y--;
d=t%13;
if(d==0) d = 13;
j=t%20;
if(j==0) j = 20;
strcpy(m,b[j-1]);
cout< }
return 0;
}

回答2: