結果

問題 No.437 cwwゲーム
ユーザー snrnsidy
提出日時 2021-10-09 13:49:29
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 4 ms / 2,000 ms
コード長 1,063 bytes
コンパイル時間 2,199 ms
コンパイル使用メモリ 195,316 KB
最終ジャッジ日時 2025-01-24 23:53:05
ジャッジサーバーID
(参考情報)
judge2 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 41
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>

using namespace std;

int dp[1<<13];
int arr[1<<13];
int main(void)
{
  cin.tie(0);
  ios::sync_with_stdio(false);

  string s;

  cin >> s;

  int n = s.length();

  for(int i=0;i<n;i++)
  {
    for(int j=i+1;j<n;j++)
    {
      for(int k=j+1;k<n;k++)
      {
        if(s[j]!=s[i] && s[j]==s[k] && s[i]!='0')
        {
            int val = (s[i]-'0')*100;
            val += (s[j]-'0')*10;
            val += (s[k]-'0');
            arr[(1<<i) + (1<<j) + (1<<k)] = val;
        }
      }
    }
  }

  for(int i=0;i<(1<<n);i++)
  {
    vector <int> v;
    for(int j=0;j<n;j++)
    {
      if((i&(1<<j))==0)
      {
        v.push_back(j);
      }
    }
    int m = v.size();
    for(int j=0;j<m;j++)
    {
      for(int k=j+1;k<m;k++)
      {
        for(int l=k+1;l<m;l++)
        {
          int mask = i + (1<<v[j]) + (1<<v[k]) + (1<<v[l]);
          dp[mask] = max(dp[mask],dp[i] + arr[mask - i]);
        }
      }
    }
  }

  int res = 0;
  for(int i=0;i<(1<<n);i++) res = max(res,dp[i]);

  cout << res << '\n';

  return 0;
}
0