結果
| 問題 |
No.10 +か×か
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2025-05-09 21:59:21 |
| 言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 3,581 ms / 5,000 ms |
| コード長 | 1,237 bytes |
| コンパイル時間 | 3,441 ms |
| コンパイル使用メモリ | 289,404 KB |
| 実行使用メモリ | 37,504 KB |
| 最終ジャッジ日時 | 2025-05-09 21:59:35 |
| 合計ジャッジ時間 | 12,653 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 12 |
ソースコード
#include <bits/stdc++.h>
using namespace std;
/////////////////// メイン ///////////////////
int main () {
//////////////////// 入力 ////////////////////
int n, t;
cin >> n >> t;
int limit = 100001;
vector<int> a(n);
for (int i=0; i<n; i++) {
cin >> a.at(i);
}
//////////////// 出力変数定義 ////////////////
string result = "";
//////////////////// 処理 ////////////////////
set<pair<string,int>> s;
for (int num : a) {
if (s.empty()) {
s.emplace("",num);
continue;
}
set<pair<string,int>> next;
set<int> check;
for (auto [str,i] : s) {
if (check.find(i+num)==check.end()&&i+num<limit) {
check.emplace(i+num);
next.emplace(str+'a',i+num);
}
if (check.find(i*num)==check.end()&&i*num<limit) {
check.emplace(i*num);
next.emplace(str+'b',i*num);
}
}
swap(s,next);
}
for (auto [str,i] : s) {
if (i==t) {
for (char c : str) {
if (c=='a') result += '+';
else if (c=='b') result += '*';
}
break;
}
}
//////////////////// 出力 ////////////////////
cout << result << endl;
//////////////////// 終了 ////////////////////
return 0;
}