C. Ayoub and Lost Array cf dp
Posted echozqn
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C. Ayoub and Lost Array cf dp相关的知识,希望对你有一定的参考价值。
Ayoub had an array aa of integers of size nn and this array had two interesting properties:
- All the integers in the array were between ll and rr (inclusive).
- The sum of all the elements was divisible by 33 .
Unfortunately, Ayoub has lost his array, but he remembers the size of the array nn and the numbers ll and rr , so he asked you to find the number of ways to restore the array.
Since the answer could be very large, print it modulo 109+7109+7 (i.e. the remainder when dividing by 109+7109+7 ). In case there are no satisfying arrays (Ayoub has a wrong memory), print 00 .
The first and only line contains three integers nn , ll and rr (1≤n≤2?105,1≤l≤r≤1091≤n≤2?105,1≤l≤r≤109 ) — the size of the lost array and the range of numbers in the array.
Print the remainder when dividing by 109+7109+7 the number of ways to restore the array.
2 1 3
3
3 2 2
1
9 9 99
711426616
In the first example, the possible arrays are : [1,2],[2,1],[3,3][1,2],[2,1],[3,3] .
In the second example, the only possible array is [2,2,2][2,2,2] .
这个题目先要意识到这是一个动态规划
他是在范围内取一个元素个数为n,对3的余数为0的集合的方案数。
这个就可以当初一种动态规划,从1到n转移。
#include <iostream> #include <stdio.h> #include <stdlib.h> using namespace std; typedef long long ll; const int maxn=2e5+100; ll mod=1e9+7,dp[maxn][4];//dp[i][j]代表余数为j时,集合元素为i的方案数 int main() { int n,l,r,a=0,b=0,c=0; cin>>n>>l>>r; int k=(r-l)/3; a=b=c=k; for(int i=l+3*k;i<=r;i++) { if(i%3==0) a++; if(i%3==1) b++; if(i%3==2) c++; } dp[1][0]=a; dp[1][1]=b; dp[1][2]=c; for(int i=2;i<=n;i++) { dp[i][0]=dp[i-1][0]*a%mod; dp[i][0]%=mod; dp[i][0]+=dp[i-1][1]*c%mod; dp[i][0]%=mod; dp[i][0]+=dp[i-1][2]*b%mod; dp[i][0]%=mod; dp[i][1]=dp[i-1][0]*b%mod; dp[i][1]%=mod; dp[i][1]+=dp[i-1][1]*a%mod; dp[i][1]%=mod; dp[i][1]+=dp[i-1][2]*c%mod; dp[i][1]%=mod; dp[i][2]=dp[i-1][0]*c%mod; dp[i][2]%=mod; dp[i][2]+=dp[i-1][1]*b%mod; dp[i][2]%=mod; dp[i][2]+=dp[i-1][2]*a%mod; dp[i][2]%=mod; } cout<<dp[n][0]<<endl; return 0; }
以上是关于C. Ayoub and Lost Array cf dp的主要内容,如果未能解决你的问题,请参考以下文章
Codeforces Round #533 (Div. 2)C. Ayoub and Lost Array
Codeforces Round #533 (Div. 2) C. Ayoub and Lost Array dp