在这个https://blog.csdn.net/lxp__/article/details/50382754答案的基础上,我把数据一个个存入vector容器中,再通过遍历得出答案
#include<iostream>
#include<string>#include<vector>
using namespace std;
string Haab_Month[] = { "pop", "no", "zip", "zotz", "tzec", "xul", "yoxkin", "mol", "chen", "yax", "zac", "ceh", "mac", "kankin", "muan", "pax", "koyab", "cumhu", "uayet" };
string Holly_Month[] = { "imix", "ik", "akbal", "kan", "chicchan", "cimi", "manik", "lamat", "muluk", "ok", "chuen", "eb", "ben", "ix", "mem", "cib", "caban", "eznab", "canac", "ahau" };
int main()
{
int n,t,day, year;
string month;
vector<string> test;
cin >> n;
t = n; //后面使用
while (n--)
{
scanf_s("%d.", &day);
cin >> month >> year;
int i, sum = 0;
for (i = 0; i < 19; i++)
{
if (Haab_Month[i] == month)
break;
}
sum = (year * 365) + (i * 20) + day;
year = sum / 260;
month = Holly_Month[sum% 20];
day = sum % 13 + 1;
test.push_back(to_string(day));
test.push_back(month);
test.push_back(to_string(year));
}
cout << t << endl;
for(int i=0;i<3*t;i+=3){
cout<<test[i]<<" "<<test[i+1]<<" "<<test[i+2]<<endl;
}
return 0;
}