結果
問題 | 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";}}