#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