結果

問題 No.52 よくある文字列の問題
ユーザー 🍡yurahuna🍡yurahuna
提出日時 2016-05-19 06:40:17
言語 C++14
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 2 ms / 5,000 ms
コード長 689 bytes
コンパイル時間 1,593 ms
コンパイル使用メモリ 173,596 KB
実行使用メモリ 4,348 KB
最終ジャッジ日時 2023-10-22 04:04:36
合計ジャッジ時間 1,980 ms
ジャッジサーバーID
(参考情報)
judge15 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
4,348 KB
testcase_01 AC 2 ms
4,348 KB
testcase_02 AC 2 ms
4,348 KB
testcase_03 AC 1 ms
4,348 KB
testcase_04 AC 2 ms
4,348 KB
testcase_05 AC 2 ms
4,348 KB
testcase_06 AC 2 ms
4,348 KB
testcase_07 AC 2 ms
4,348 KB
testcase_08 AC 2 ms
4,348 KB
testcase_09 AC 2 ms
4,348 KB
testcase_10 AC 2 ms
4,348 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
#define int long long   // <-----!!!!!!!!!!!!!!!!!!!

#define rep(i,n) for (int i=0;i<(n);i++)
#define rep2(i,a,b) for (int i=(a);i<(b);i++)
#define rrep(i,n) for (int i=(n)-1;i>=0;i--)
#define rrep2(i,a,b) for (int i=(b)-1;i>=(a);i--)
#define all(a) (a).begin(),(a).end()

typedef long long ll;
typedef pair<int, int> P;

set<string> ss;
string s;
int n;

void dfs(string t, int l, int r) {
	if (l == r) {
		ss.insert(t);
		return;
	}
	dfs(t + s[l], l + 1, r);
	dfs(t + s[r - 1], l, r - 1);
}

signed main() {
    std::ios::sync_with_stdio(false);
    std::cin.tie(0);

	cin >> s;
	n = s.size();
	dfs("", 0, n);
	cout << ss.size() << endl;
}
0