ZOJ 3785 What day is that day?(今天是星期几?)
Description |
题目描述 |
It's Saturday today, what day is it after 11 + 22 + 33 + ... + NN days? |
今天是星期六,11 + 22 + 33 + ... + NN 天后是星期几? |
Input |
输入 |
There are multiple test cases. The first line of input contains an integer T indicating the number of test cases. For each test case:
There is only one line containing one integer N (1 <= N <= 1000000000). |
多组测试样例。 输入的首行是一个整数T表示测试样例的数量。每个测试样例包含:
只有一行,且每行只有一个整数N (1 <= N <= 1000000000)。 |
Output |
输出 |
For each test case, output one string indicating the day of week. |
每个测试样例输出一个字符串表示星期几。 |
Sample Input - 输入样例 |
Sample Output - 输出样例 |
2 1 2 |
Sunday Thursday |
Hint |
提示 |
A week consists of Sunday, Monday, Tuesday, Wednesday, Thursday, Friday and Saturday. |
一周中包含Sunday, Monday, Tuesday, Wednesday, Thursday, Friday and Saturday。 |
【题解】
想算出最后是星期几,只要把天数模7就能得到增长了的星期数,从而换算出具体星期。
因此我们需要计算的式子可表示为:
(11+ 22+ 33+...+ NN)%7
11%7+ 22%7+ 33%7+...+ NN%7
然后对于大等于7的数,aN%7可以得到:
7N%7 = (7%7)N%7 = 0N,8N%7 = (8%7)N%7 = 1N,…………以此类推
后继的元素全部遵循这个规律,因此所求a的值为[ 0, 6]。
对于aN%7,a属于[ 0, 6]:
元素\次方%7 |
0 |
1 |
2 |
3 |
4 |
5 |
6 |
0 |
0%7已经为0,其结果全部为0 |
||||||
1 |
1 |
1……出现循环 |
|||||
2 |
1 |
2 |
4 |
1……出现循环 |
|||
3 |
1 |
3 |
2 |
6 |
4 |
5 |
1……出现循环 |
4 |
1 |
4 |
2 |
1……出现循环 |
|||
5 |
1 |
5 |
4 |
6 |
2 |
3 |
1……出现循环 |
6 |
1 |
6 |
1……出现循环 |
所求式子可展开为:
第一层 |
11 |
22 |
33 |
44 |
55 |
66 |
07 |
第二层 |
18 |
29 |
310 |
411 |
512 |
613 |
014 |
第三层 |
115 |
216 |
317 |
418 |
519 |
620 |
021 |
第四层 |
122 |
223 |
324 |
425 |
526 |
627 |
028 |
第五层 |
129 |
230 |
331 |
432 |
533 |
634 |
035 |
第六层 |
136 |
237 |
338 |
439 |
540 |
641 |
042 |
第七层 |
…………………………………………………… |
然后把每层加起来再%7,可以得到长度为6*7 = 42的循环节。
然后根据每层的循环节套上每个元素的循环节,得到最终循环节,长度为42*7 = 294
附:原本想比较科学地证明最终循环节的长度是294,最后发现坑越挖越大,然后以现在的渣水平填不上,就弃了……
【代码 C++】
1 #include<cstdio> 2 int day[294] = { 3 0, 1, 5, 4, 1, 4, 5, 5, 6, 0, 4, 6, 0, 6, 6, 0, 2, 0, 1, 6, 4 0, 0, 1, 5, 6, 3, 0, 6, 6, 0, 1, 4, 6, 5, 6, 6, 0, 2, 4, 5, 5 0, 6, 6, 0, 4, 3, 0, 3, 4, 4, 5, 6, 3, 5, 6, 5, 5, 6, 1, 6, 6 0, 5, 6, 6, 0, 4, 5, 2, 6, 5, 5, 6, 0, 3, 5, 4, 5, 5, 6, 1, 7 3, 4, 6, 5, 5, 6, 3, 2, 6, 2, 3, 3, 4, 5, 2, 4, 5, 4, 4, 5, 8 0, 5, 6, 4, 5, 5, 6, 3, 4, 1, 5, 4, 4, 5, 6, 2, 4, 3, 4, 4, 9 5, 0, 2, 3, 5, 4, 4, 5, 2, 1, 5, 1, 2, 2, 3, 4, 1, 3, 4, 3, 10 3, 4, 6, 4, 5, 3, 4, 4, 5, 2, 3, 0, 4, 3, 3, 4, 5, 1, 3, 2, 11 3, 3, 4, 6, 1, 2, 4, 3, 3, 4, 1, 0, 4, 0, 1, 1, 2, 3, 0, 2, 12 3, 2, 2, 3, 5, 3, 4, 2, 3, 3, 4, 1, 2, 6, 3, 2, 2, 3, 4, 0, 13 2, 1, 2, 2, 3, 5, 0, 1, 3, 2, 2, 3, 0, 6, 3, 6, 0, 0, 1, 2, 14 6, 1, 2, 1, 1, 2, 4, 2, 3, 1, 2, 2, 3, 0, 1, 5, 2, 1, 1, 2, 15 3, 6, 1, 0, 1, 1, 2, 4, 6, 0, 2, 1, 1, 2, 6, 5, 2, 5, 6, 6, 16 0, 1, 5, 0, 1, 0, 0, 1, 3, 1, 2, 0, 1, 1, 2, 6, 0, 4, 1, 0, 17 0, 1, 2, 5, 0, 6, 0, 0, 1, 3, 5, 6, 1, 0 18 }; 19 char opt[7][10] = { 20 "Saturday", "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday" 21 }; 22 int main(){ 23 int t, a; 24 scanf("%d", &t); 25 while (t--){ 26 scanf("%d", &a); 27 puts(opt[day[a % 294]]); 28 } 29 return 0; 30 }
ZOJ 3785