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