TakahiroNakamori

TakahiroNakamori

ナカモリタカヒロ

 
 

Payment

問題

E – Payment
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「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;

int main() {
  string S;
  cin >> S;

  reverse(S.begin(), S.end());
  S += '0';

  int n = S.size();

  /*
   dp[i][j]:末尾から i 桁目まで、くりさがりが j(bool) のときの最小値
   */
  vector<vector<int>> dp(n + 1, vector<int>(2, INF));
  dp[0][0] = 0;

  for(int i = 0; i < n; ++i) {
    for(int j = 0; j < 2; ++j) {
      int x = S[i] - '0';
      for(int a = 0; a < 10; ++a) {
        int ni = i + 1;
        int nj = 0;
        int b = a - j - x;
        if(b < 0) {
          nj = 1;
          b += 10;
        }
        dp[ni][nj] = min(dp[ni][nj], dp[i][j] + a + b);
      }
    }
  }

  int ans = dp[n][0];
  cout << ans << endl;
  return 0;
}