# | User | Rating |
---|---|---|
1 | jiangly | 3977 |
2 | tourist | 3815 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3614 |
5 | orzdevinwang | 3526 |
6 | ecnerwala | 3514 |
7 | Benq | 3483 |
8 | hos.lyric | 3381 |
9 | gamegame | 3374 |
10 | heuristica | 3358 |
# | User | Contrib. |
---|---|---|
1 | cry | 170 |
2 | -is-this-fft- | 162 |
2 | Um_nik | 162 |
4 | atcoder_official | 160 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 154 |
8 | luogu_official | 152 |
8 | awoo | 152 |
10 | TheScrasse | 147 |
Name |
---|
You will have TLE because
T<=10^5
andb<=10^5
, your solution is O(T*(b-a)*(your recursion)).You have WA because you should add here
this
mem[x] %= MOD;
Use precalc to solve it.
thanks a lot...
I should learn one that you said
I didn't find anything can you help me?
Firstly we try change your recursive dp for linear (and we will pre calculate("precalc" or "pre calc") result in array to find next time by O(1)).
Now we can find fastly your dp(x) by d[x]
After this we must to find sum of all elements from
d[a]
tod[b]
we can do it by create a new array that will have
all sum from 1 to i(sum[i]=d[1]+...+d[i]) by precalc
then we know that answer for sum from
a
tob
like thiscout<<sum[b]-sum[a-1];
You can look for my code http://codeforces.net/contest/474/submission/9871904
Thank solved :D
Why you are creating new accounts
Cause I'm afraid of down votes...