結果
問題 | No.52 よくある文字列の問題 |
ユーザー | m1025o1184t |
提出日時 | 2019-12-24 01:52:38 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 637 bytes |
コンパイル時間 | 1,806 ms |
コンパイル使用メモリ | 172,720 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-09-19 06:04:34 |
合計ジャッジ時間 | 2,128 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 11 |
ソースコード
#include <bits/stdc++.h> #define rep(i,n) for(int i=0;i<(n);++i) #define all(a) (a).begin(),(a).end() #define dunk(a) cout << (a) << endl using namespace std; typedef long long ll; int main() { ios::sync_with_stdio(false); cin.tie(0); string S; cin >> S; int n = S.size(); set<string> st; //left-start -> 0 right-start -> 1 for (int bit = 0; bit < (1 << n - 1); ++bit) { string res = ""; int a = 0; int b = n - 1; for (int i = 0; i < n - 1; ++i) { if (bit & (1 << i)) { res += S[a]; a++; } else { res += S[b]; b--; } } res += S[a]; st.insert(res); } dunk(st.size()); return 0; }