結果
| 問題 | No.636 硬貨の枚数2 | 
| コンテスト | |
| ユーザー | 👑 | 
| 提出日時 | 2020-02-17 20:24:44 | 
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) | 
| 結果 | 
                                WA
                                 
                             | 
| 実行時間 | - | 
| コード長 | 2,079 bytes | 
| コンパイル時間 | 674 ms | 
| コンパイル使用メモリ | 69,688 KB | 
| 実行使用メモリ | 5,248 KB | 
| 最終ジャッジ日時 | 2024-10-06 15:10:26 | 
| 合計ジャッジ時間 | 2,652 ms | 
| ジャッジサーバーID (参考情報) | judge5 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 4 | 
| other | AC * 60 WA * 5 | 
ソースコード
#include <iostream>
#include <algorithm>
using namespace std;
int dp[10000][2];
int main(){
    string s;cin>>s;
    reverse(s.begin(),s.end());
    for(int i = 0; 10000 > i; i++){
      dp[i][0] = -1;
      dp[i][1] = -1;
    }
    for(int j = 0; 10 > j; j++){
      if(s[0]-'0' > j){
        if(dp[0][1] == -1)dp[0][1] = (j>4?j-4:j)+(10+j-(s[0]-'0')>4?10+j-(s[0]-'0')-4:10+j-(s[0]-'0'));
        else dp[0][1] = min(dp[0][1],(j>4?j-4:j)+(10+j-(s[0]-'0')>4?10+j-(s[0]-'0')-4:10+j-(s[0]-'0')));
      }else{
        if(dp[0][0] == -1)dp[0][0] = (j>4?j-4:j)+(j-(s[0]-'0')>4?j-(s[0]-'0')-4:j-(s[0]-'0'));
        else dp[0][0] = min(dp[0][0],(j>4?j-4:j)+(j-(s[0]-'0')>4?j-(s[0]-'0')-4:j-(s[0]-'0')));
      }
    }
    for(int i = 1; s.size() > i; i++){
      for(int j = 0; 10 > j; j++){
        //dp[i-1][1]の処理
        if(s[i]-'0' >= j){
          if(dp[i][1] == -1)dp[i][1] = dp[i-1][1]+(j>=5?j-4:j)+(10+j-(s[i]-'0'+1)>4?10+j-(s[i]-'0'+1)-4:10+j-(s[i]-'0'+1));
          else dp[i][1] = min(dp[i][1],dp[i-1][1]+(j>=5?j-4:j)+(10+j-(s[i]-'0'+1)>4?10+j-(s[i]-'0'+1)-4:10+j-(s[i]-'0'+1)));
        }else{
          if(dp[i][0] == -1)dp[i][0] = dp[i-1][1]+(j>=5?j-4:j)+(j-(s[i]-'0'+1)>4?j-(s[i]-'0'+1)-4:j-(s[i]-'0'+1));
          else dp[i][0] = min(dp[i][0],dp[i-1][1]+(j>=5?j-4:j)+(j-(s[i]-'0'+1)>4?j-(s[i]-'0'+1)-4:j-(s[i]-'0'+1)));
        }
        //dp[i-1][0]の処理
        if(s[i]-'0' > j){
          if(dp[i][1] == -1)dp[i][1] = dp[i-1][0]+(j>=5?j-4:j)+(10+j-(s[i]-'0')>4?10+j-(s[i]-'0')-4:10+j-(s[i]-'0'));
          else dp[i][1] = min(dp[i][1],dp[i-1][0]+(j>=5?j-4:j)+(10+j-(s[i]-'0')>4?10+j-(s[i]-'0')-4:10+j-(s[i]-'0')));
        }else{
          if(dp[i][0] == -1)dp[i][0] = dp[i-1][0]+(j>=5?j-4:j)+(j-(s[i]-'0')>4?j-(s[i]-'0')-4:j-(s[i]-'0'));
          else dp[i][0] = min(dp[i][0],dp[i-1][0]+(j>=5?j-4:j)+(j-(s[i]-'0')>4?j-(s[i]-'0')-4:j-(s[i]-'0')));
        }
        
      }
    }
    // for(int i = 0; s.size() > i; i++){
    //   cout << dp[i][0] << " " << dp[i][1] << endl;
    // }
    cout << min(dp[s.size()-1][0],dp[s.size()-1][1]+1) << endl;
}
            
            
            
        