結果

問題 No.1106 🦉 何事もバランスが大事
ユーザー SSRS
提出日時 2020-07-03 22:05:34
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
WA  
実行時間 -
コード長 715 bytes
コンパイル時間 1,807 ms
コンパイル使用メモリ 175,696 KB
実行使用メモリ 6,948 KB
最終ジャッジ日時 2024-09-17 02:08:04
合計ジャッジ時間 4,028 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3 WA * 2
other AC * 4 WA * 73
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
vector<int> diff = {0, -1, -2, 1, 0};
int main(){
  long long N;
  cin >> N;
  string S;
  while (N > 0){
    S += N % 5 + '0';
    N /= 5;
  }
  reverse(S.begin(), S.end());
  int M = S.size();
  vector<vector<vector<long long>>> dp(M + 1, vector<vector<long long>>(120, vector<long long>(2, 0)));
  dp[0][60][0] = 1;
  for (int i = 0; i < M; i++){
    for (int j = 0; j < 120; j++){
      for (int k = 0; k < 2; k++){
        if (dp[i][j][k]){
          for (int d = 0; d <= (k ? 4 : S[i] - '0'); d++){
            dp[i + 1][j + diff[d]][k || d < S[i] - '0'] += dp[i][j][k];
          }
        }
      }
    }
  }
  cout << dp[M][60][0] + dp[M][60][1] - 1 << endl;
}
0