結果

問題 No.52 よくある文字列の問題
ユーザー ren0824xemnasren0824xemnas
提出日時 2015-09-22 23:19:28
言語 C++11
(gcc 11.4.0)
結果
AC  
実行時間 2 ms / 5,000 ms
コード長 651 bytes
コンパイル時間 573 ms
コンパイル使用メモリ 72,648 KB
実行使用メモリ 4,348 KB
最終ジャッジ日時 2023-10-22 04:00:52
合計ジャッジ時間 1,078 ms
ジャッジサーバーID
(参考情報)
judge12 / judge15
このコードへのチャレンジ
(要ログイン)

テストケース

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

ソースコード

diff #

#include<iostream>
#include<string>
#include<vector>
#include<map>
using namespace std;
typedef long long int ll;
typedef pair<ll,ll> P;
#define INF 1000000000
map<string,int> data;
void dfs(string now,string str,int cou);
int lim;

int main(){
	string str;
	cin >> str;
	lim = str.size();
	string t = "";
	dfs(t,str,0);
	cout << data.size() << endl;
}

void dfs(string now,string str,int cou){
	if(cou == lim) {
		data[now] = 1;
		return;
	}
	int len = str.size();
	string tmp = str;
	string next = now;
	tmp.erase(0,1);
	next += str[0];
	dfs(next,tmp,cou+1);
	tmp = str;
	next = now;
	tmp.erase(len-1,1);
	next += str[len-1];
	dfs(next,tmp,cou+1);
}
0