分析:判断闰年的时候要预处理,不然会超时。
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<cstdlib>
using namespace std;
int Hash[7]= {5,6,0,1,2,3,4};
int run[13]= {0,31,29,31,30,31,30,31,31,30,31,30,31};
int pin[13]= {0,31,28,31,30,31,30,31,31,30,31,30,31};
int yy[10000];
void init() {
yy[1600]=1;
for(int i=1601; i<=9600; i++) {
if(i%400==0||(i%100&&i%4==0)) {
yy[i]=yy[i-1]+1;
} else {
yy[i]=yy[i-1];
}
}
}
int main() {
int y,m,d;
init();
while(~scanf("%d%d%d",&y,&m,&d)) {
int ans=(y-1600)*365;
ans+=yy[y-1];
if(y%400==0||(y%100!=0&&y%4==0)) {
for(int i=0; i<m; i++) {
ans+=run[i];
}
ans+=d;
} else {
for(int i=0; i<m; i++) {
ans+=pin[i];
}
ans+=d;
}
printf("%d\n",Hash[ans%7]);
}
return 0;
}
本文介绍了一个高效的算法,用于计算从1600年至9600年间任意一天是一周中的哪一天。通过预处理闰年和平年的天数,并使用哈希表映射星期几的数字,确保了算法的高效性和准确性。
911

被折叠的 条评论
为什么被折叠?



