Task: | Dice Summation |
Sender: | Niilo |
Submission time: | 2024-11-27 16:23:54 +0200 |
Language: | C++ (C++17) |
Status: | READY |
Result: | ACCEPTED |
test | verdict | time | |
---|---|---|---|
#1 | ACCEPTED | 0.00 s | details |
#2 | ACCEPTED | 0.00 s | details |
#3 | ACCEPTED | 0.00 s | details |
#4 | ACCEPTED | 0.00 s | details |
#5 | ACCEPTED | 0.00 s | details |
#6 | ACCEPTED | 0.00 s | details |
#7 | ACCEPTED | 0.00 s | details |
#8 | ACCEPTED | 0.00 s | details |
#9 | ACCEPTED | 0.00 s | details |
#10 | ACCEPTED | 0.00 s | details |
#11 | ACCEPTED | 0.00 s | details |
#12 | ACCEPTED | 0.00 s | details |
#13 | ACCEPTED | 0.01 s | details |
#14 | ACCEPTED | 0.01 s | details |
#15 | ACCEPTED | 0.01 s | details |
#16 | ACCEPTED | 0.01 s | details |
#17 | ACCEPTED | 0.01 s | details |
#18 | ACCEPTED | 0.00 s | details |
#19 | ACCEPTED | 0.01 s | details |
#20 | ACCEPTED | 0.00 s | details |
Code
#include <iostream> #include <cmath> #include <vector> #include <cassert> #include <algorithm> using namespace std; #define rep(i, a, b) for(int i=a;i<(b);++i) #define all(x) begin(x),end(x) #define sz(x) int((x).size()) using ll = long long; using pii = pair<int,int>; using vi = vector<int>; const int M = 1e9+7; const int N = 1e6+1; int R[N]; int main() { int n; cin >> n; R[0] = R[1] = 1; rep(i,2,n+1) { ll s = 0; rep(j,max(i-6,0),i) s += R[j]; R[i] = s % M; } cout << R[n] << '\n'; }
Test details
Test 1
Verdict: ACCEPTED
input |
---|
1 |
correct output |
---|
1 |
user output |
---|
1 |
Test 2
Verdict: ACCEPTED
input |
---|
2 |
correct output |
---|
2 |
user output |
---|
2 |
Test 3
Verdict: ACCEPTED
input |
---|
3 |
correct output |
---|
4 |
user output |
---|
4 |
Test 4
Verdict: ACCEPTED
input |
---|
4 |
correct output |
---|
8 |
user output |
---|
8 |
Test 5
Verdict: ACCEPTED
input |
---|
5 |
correct output |
---|
16 |
user output |
---|
16 |
Test 6
Verdict: ACCEPTED
input |
---|
6 |
correct output |
---|
32 |
user output |
---|
32 |
Test 7
Verdict: ACCEPTED
input |
---|
7 |
correct output |
---|
63 |
user output |
---|
63 |
Test 8
Verdict: ACCEPTED
input |
---|
8 |
correct output |
---|
125 |
user output |
---|
125 |
Test 9
Verdict: ACCEPTED
input |
---|
9 |
correct output |
---|
248 |
user output |
---|
248 |
Test 10
Verdict: ACCEPTED
input |
---|
10 |
correct output |
---|
492 |
user output |
---|
492 |
Test 11
Verdict: ACCEPTED
input |
---|
50 |
correct output |
---|
660641036 |
user output |
---|
660641036 |
Test 12
Verdict: ACCEPTED
input |
---|
1000 |
correct output |
---|
937196411 |
user output |
---|
937196411 |
Test 13
Verdict: ACCEPTED
input |
---|
123456 |
correct output |
---|
113810539 |
user output |
---|
113810539 |
Test 14
Verdict: ACCEPTED
input |
---|
654321 |
correct output |
---|
615247550 |
user output |
---|
615247550 |
Test 15
Verdict: ACCEPTED
input |
---|
999998 |
correct output |
---|
39372206 |
user output |
---|
39372206 |
Test 16
Verdict: ACCEPTED
input |
---|
999999 |
correct output |
---|
511319454 |
user output |
---|
511319454 |
Test 17
Verdict: ACCEPTED
input |
---|
1000000 |
correct output |
---|
874273980 |
user output |
---|
874273980 |
Test 18
Verdict: ACCEPTED
input |
---|
1001 |
correct output |
---|
94201505 |
user output |
---|
94201505 |
Test 19
Verdict: ACCEPTED
input |
---|
999997 |
correct output |
---|
74225807 |
user output |
---|
74225807 |
Test 20
Verdict: ACCEPTED
input |
---|
40 |
correct output |
---|
567401756 |
user output |
---|
567401756 |