結果
| 問題 | No.10 +か×か | 
| コンテスト | |
| ユーザー |  alpha_virginis | 
| 提出日時 | 2016-11-14 00:48:20 | 
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) | 
| 結果 | 
                                WA
                                 
                             | 
| 実行時間 | - | 
| コード長 | 1,378 bytes | 
| コンパイル時間 | 1,484 ms | 
| コンパイル使用メモリ | 167,584 KB | 
| 実行使用メモリ | 42,112 KB | 
| 最終ジャッジ日時 | 2024-11-25 22:08:17 | 
| 合計ジャッジ時間 | 2,257 ms | 
| ジャッジサーバーID (参考情報) | judge2 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 4 WA * 8 | 
ソースコード
#include <bits/stdc++.h>
int n;
int total;
int xs[64];
uint64_t prev[64][100100];
int main() {
  scanf("%d", &n);
  scanf("%d", &total);
  for(int i = 0; i < n; ++i) {
    scanf("%d", &xs[i]);
  }
 
  // step 2
  prev[0][xs[0]] = '!';
  for(int i = 1; i < n; ++i) {
    for(int j = 0; j < 100100; ++j) {
      // printf("(i, j) = (%d, %d)\n", i, j);
      int x1 = j + xs[i];
      int x2 = j * xs[i];
      uint64_t y1 = (prev[i-1][j] << 1) | 1ULL;
      uint64_t y2 = (prev[i-1][j] << 1);
      if( x1 < 100100 ) {
        // printf("(i, x1) = (%d, %d)\n", i, x1);
        prev[i][x1] = std::max(prev[i][x1], y1);
      }
      if( x2 < 100100 ) {
        // printf("(i, x2) = (%d, %d)\n", i, x2);
        prev[i][x2] = std::max(prev[i][x2], y2);
      }
    }
    // for(int j = 0; j < 32; ++j) {
    //   printf("%c", prev[i][j]);
    // }
    // printf("\n");
  }
  for(int i = 0; i < n - 1; ++i) {
    putchar( (prev[n-1][total] & (1ULL << i)) ? '+' : '*' );
  }
  putchar('\n');
                  
  // std::string ans;
  // int x = total;
  // for(int i = n - 1; i >= 1; --i) {
  //   // printf("#(i, x, prev[i][x]) = (%d, %d, %c)\n", i, x, prev[i][x]);
  //   char c = prev[i][x];
  //   ans += c;
  //   if( c == '+' ) x -= xs[i];
  //   if( c == '*' ) x /= xs[i];
  // }
  // std::reverse(ans.begin(), ans.end());
  // printf("%s\n", ans.c_str());
  return 0;
}
            
            
            
        