Task: | Dice Combinations |
Sender: | Farah |
Submission time: | 2024-09-16 16:00:43 +0300 |
Language: | Python3 (CPython3) |
Status: | READY |
Result: | ACCEPTED |
test | verdict | time | |
---|---|---|---|
#1 | ACCEPTED | 0.02 s | details |
#2 | ACCEPTED | 0.02 s | details |
#3 | ACCEPTED | 0.02 s | details |
#4 | ACCEPTED | 0.02 s | details |
#5 | ACCEPTED | 0.02 s | details |
#6 | ACCEPTED | 0.02 s | details |
#7 | ACCEPTED | 0.02 s | details |
#8 | ACCEPTED | 0.02 s | details |
#9 | ACCEPTED | 0.02 s | details |
#10 | ACCEPTED | 0.02 s | details |
#11 | ACCEPTED | 0.02 s | details |
#12 | ACCEPTED | 0.02 s | details |
#13 | ACCEPTED | 0.07 s | details |
#14 | ACCEPTED | 0.32 s | details |
#15 | ACCEPTED | 0.47 s | details |
#16 | ACCEPTED | 0.46 s | details |
#17 | ACCEPTED | 0.46 s | details |
#18 | ACCEPTED | 0.02 s | details |
#19 | ACCEPTED | 0.47 s | details |
#20 | ACCEPTED | 0.02 s | details |
Code
MOD = 10**9 + 7 def count_ways_to_sum(n): # DP array to store the number of ways to form sum i dp = [0] * (n + 1) dp[0] = 1 # There's 1 way to form sum 0 (doing nothing) window_sum = dp[0] # This will hold the sum of the last six dp values for i in range(1, n + 1): # Calculate dp[i] based on the running sum of the last six values dp[i] = window_sum % MOD # Update the sliding window sum window_sum = (window_sum + dp[i]) % MOD # If we are past the first six elements, subtract dp[i-6] if i >= 6: window_sum = (window_sum - dp[i - 6]) % MOD return dp[n] # Input n = int(input()) # Output print(count_ways_to_sum(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 |