結果
問題 | No.1257 変わった平均値 |
ユーザー |
![]() |
提出日時 | 2020-10-17 03:17:36 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 2,226 bytes |
コンパイル時間 | 2,009 ms |
コンパイル使用メモリ | 171,536 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-21 01:45:51 |
合計ジャッジ時間 | 2,572 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 25 |
ソースコード
#include <bits/stdc++.h>using namespace std;typedef long long ll;int D, E, F;bool flag = false;string sovle(int a, int b, int c) {string t = "";flag = false;while (true) {if (2 * a <= D && 2 * b <= E) {a *= 2;b *= 2;if (t.length() == 0) {t = "1 F 1 F";} else {t += " 1 F 1 F";}} else {break;}}while (true) {if (2 * a <= D && 2 * c <= F) {a *= 2;c *= 2;if (t.length() == 0) {t = "1 E 1 E";} else {t += " 1 E 1 E";}} else {break;}}while (true) {if (2 * b <= E && 2 * c <= F) {b *= 2;c *= 2;if (t.length() == 0) {t = "1 D 1 D";} else {t += " 1 D 1 D";}} else {break;}}if (a == D && b == E && c == F) {flag = true;}return t;}int main() {int x[3], y[3];for (int i = 0; i < 3; i++) {cin >> x[i];}cin >> D >> E >> F;vector<int> v{0, 1, 2};string best = string(100, 'a');do {string t = sovle(x[v[0]], x[v[1]], x[v[2]]);string s = "";if (v[0] != 0 || v[1] != 1) s = "2";if (s.length() == 0) {if (flag) {if (best.length() > t.length()) {best = t;}}} else {if (flag) {if (t.length() == 0) {if (best.length() > s.length()) {best = s;}} else {if (best.length() < t.length() + s.length()) {best = s + " " + t;}}}}} while (next_permutation(v.begin(), v.end()));if (best.length() == 100) {cout << "No\n";} else {cout << "Yes\n";if (best.length() == 0) best = "2";cout << best << "\n";}return 0;}