TakahiroNakamori

TakahiroNakamori

ナカモリタカヒロ

 
 

FG operation

問題

D – FG operation
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

記録

解法

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<int, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 62;
// const int INF = 1001001001;
const ll mod = 998244353;

// 21:28 22:11 43分

int main() {
  int N;
  cin >> N;

  vector<ll> A(N);
  rep(i, N) {
    cin >> A[i];
  }

  vector<vector<ll>> dp(N+1, vector<ll>(10));
  rep(i, N) {
    ll f = 0;
    ll g = 0;
    if (i == 0) {
      f = A[i];
      dp[i][f] = 1;
    } else {
      rep(j, 10) {
        if (dp[i-1][j] == 0) {
          continue;
        }
        f =(ll) (j + A[i]) % 10;
        g =(ll) (j * A[i]) % 10;
        dp[i][f] += dp[i-1][j];
        dp[i][g] += dp[i-1][j];
        dp[i][f] %= mod;
        dp[i][g] %= mod;
      }
    }
  }

  rep(i, 10) {
    cout << dp[N-1][i] % mod << endl;
  }

  return 0;
}