結果
問題 | No.8081 HQ9+ |
ユーザー |
![]() |
提出日時 | 2021-04-01 22:37:00 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 5 ms / 2,000 ms |
コード長 | 1,247 bytes |
コンパイル時間 | 3,192 ms |
コンパイル使用メモリ | 204,424 KB |
最終ジャッジ日時 | 2025-01-20 07:05:37 |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 21 |
ソースコード
#include <bits/stdc++.h> using namespace std; using Int = long long; constexpr static int mod = 1e9 + 7; constexpr static int inf = (1 << 30) - 1; constexpr static Int infll = (1LL << 61) - 1; int Competitive_Programming = (ios_base::sync_with_stdio(false), cin.tie(nullptr), cout << fixed << setprecision(15), 0); #pragma GCC target("avx2") #pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") #include <vector> #include <algorithm> template <typename T> vector<T> divisor(T n) { vector<T> divisor; for (T i = 1; i * i <= n; i++) { if (n % i == 0) { divisor.push_back(i); if (i * i != n) divisor.push_back(n / i); } } sort(divisor.begin(), divisor.end()); return divisor; } int main() { int N, cnt = 0; cin >> N; string s; cin >> s; for (int i = 0; i < N; i++) { if (s[i] == 'Q') cnt++; if (s[i] == 'H') { cout << -1 << "\n"; return 0; } } if (cnt == 0) { cout << -1 << "\n"; return 0; } else { auto divs = divisor(N); for (auto &d : divs) { int len = N / d; string code = s.substr(0, len), ret = ""; for (char op : code) { if (op == 'Q') ret += code; } if (s == ret) { cout << code; return 0; } } cout << -1 << "\n"; } }