結果

問題 No.437 cwwゲーム
ユーザー __NCAstar
提出日時 2016-10-28 23:20:45
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
WA  
実行時間 -
コード長 981 bytes
コンパイル時間 1,322 ms
コンパイル使用メモリ 160,776 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-11-24 06:52:06
合計ジャッジ時間 2,882 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 40 WA * 1
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<bits/stdc++.h>

#define REP(i,s,n) for(int i=s;i<n;++i)
#define rep(i,n) REP(i,0,n)

using namespace std;

int cnt[10];

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

  int n = s.size();
  int answer = 0;

  rep(bit,(1<<n)) {
    int cost = 0;
    vector<bool> used(n,false);
    rep(i,n) if( (bit>>i) & 1 ) {
      used[i] = true;
    }

    for(int i=n-1;i>=0;--i) if( (bit>>i) & 1 ) {
        memset(cnt,0,sizeof cnt);
        REP(j,i+1,n) if( !used[j] && ( s[i] != s[j] ) ) {
          ++cnt[s[j]-'0'];
        }
        int num = -1;
        for(int j=9;j>=0;--j) if( cnt[j] >= 2 ) {
            num = j;
            break;
          }
        if( num == -1 ) continue;
        int step = 0;
        REP(j,i+1,n) if( !used[j] && (s[j]-'0') == num ) {
          if( step >= 2 ) break;
          used[j] = true;
          ++step;
        }
        cost += ( (s[i]-'0') * 100 + num * 10 + num );
    }
    answer = max(answer,cost);
  }


  cout << answer << endl;
  return 0;
}
0