#include <bits/stdc++.h>
using namespace std;
const int N = 3e5+10;
const int mod = 1e9+7;
typedef long long ll;
ll dp[N][100];
int n;
ll a[N];
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cin>>n;
for(int i=1;i<=n;i++)
{
cin>>a[i];
}
if(n==1)
{
if(a[1]<10)dp[1][a[1]]++;
for(int i=0;i<=9;i++)
{
cout<<dp[1][i]<<' ';
}
cout<<'\n';
return 0;
}
dp[n-1][(a[n]*a[n-1])%10]++;
dp[n-1][(a[n]+a[n-1])%10]++;
for(int i=n-2;i>=1;i--)
{
for(int j=0;j<=9;j++)
{
dp[i][(j*a[i])%10]=(dp[i][(j*a[i])%10]+dp[i+1][j])%mod;
dp[i][(j+a[i])%10]=(dp[i][(j+a[i])%10]+dp[i+1][j])%mod;
}
}
for(int i=0;i<=9;i++)
{
cout<<dp[1][i]%mod<<' ';
}
cout<<'\n';
return 0;
}
线性dp

京公网安备 11010502036488号