結果
問題 |
No.3299 K-th MMA String
|
ユーザー |
|
提出日時 | 2025-10-05 14:34:02 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,032 bytes |
コンパイル時間 | 8,410 ms |
コンパイル使用メモリ | 379,712 KB |
実行使用メモリ | 67,064 KB |
最終ジャッジ日時 | 2025-10-05 14:34:27 |
合計ジャッジ時間 | 13,107 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 10 WA * 10 |
ソースコード
#pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") #include <bits/stdc++.h> #include <atcoder/all> using namespace std; typedef long long ll; const int INF = 1<<30; const ll INFLL = 1LL<<60; //const ll MOD = 998244353; const double INFD = 1.0E10; const int dx[4] = {1, 0, -1, 0}; const int dy[4] = {0, -1, 0, 1}; //const int dx[8] = {1, 1, 0, -1, -1, -1, 0, 1}; //const int dy[8] = {0, 1, 1, 1, 0, -1, -1, -1}; using Pair = pair<ll, ll>; using Graph = vector<vector<ll>>; using mint = atcoder::modint998244353; int main(){ ios::sync_with_stdio(false); cin.tie(nullptr); cout << fixed << setprecision(15); ll n, k; cin >> n >> k; if (n <= 21){ vector<string> strs; for (int i = 0; i < (1<<n); i++){ string str; for (int j = 0; j < n; j++){ str.push_back('0' + ((i >> j) & 1)); } bool ok = false; for (int j = 0; j < n - 2; j++){ if (str.substr(j, 3) == "110") ok = true; } if (ok) strs.push_back(str); } sort(strs.begin(), strs.end()); //cerr << strs.size() << endl; string ans; for (auto c : strs[k - 1]){ if (c == '0') ans.push_back('A'); else ans.push_back('M'); } cout << ans << endl; } else{ ll m = 18; vector<string> strs; for (int i = 0; i < (1<<m); i++){ string str; for (int j = 0; j < m; j++){ str.push_back('0' + ((i >> j) & 1)); } strs.push_back(str); } sort(strs.begin(), strs.end()); assert(strs.size() >= k); string ans; for (auto c : strs[k - 1]){ if (c == '0') ans.push_back('A'); else ans.push_back('M'); } //20桁の頭 + AAAAA + MMA assert(n - m - 3 >= 0); ans += string(n - m - 3,'A'); ans += "MMA"; cout << ans << endl; } return 0; }