题目描述
有1-13这13个数字写成了一个序列,可是中间没有分隔成了一串数字,问是否有唯一分离。
如12345678910111213
为1,2,3,4,5,6,7,8,9,10,11,12,13
或者12,3,4,5,6,7,8,9,10,11,1,2,13
输入
每行一个序列(不超过10000行)。
输出
唯一分离输出“Y”,否则“N”。
样例输入
12345678910111213
14235126137108911
样例输出
N
Y
解决方案:搜索题能搜出一种以上就是N
找规律的请看11245121367183910只有一种分离方法11,2,4,5,12,13,6,7,1,8,3,9,10建议用搜索
用深搜 dfs+回溯
#include<stdio.h>
#include<iostream>
using namespace std;
int num,vis[14];
char str[17];
void dfs(int n)
{
if(n==17){
num++;
return ;
}
else{
int a,b;
if(n<16){
a=str[n]-'0';
b=str[n+1]-'0';
}
else a=str[n]-'0';
if(a==1 && b<=3){
if(!vis[a*10+b]){
vis[a*10+b]=1;
dfs(n+2);
vis[a*10+b]=0;
}
}
if(!vis[a]){
vis[a]=1;
dfs(n+1);
vis[a]=0;
}
}
}
int main()
{
while(cin>>str){
num=0;
for(int i=1;i<=13;i++) vis[i]=0;
dfs(0);
if(num>=2) printf("N\n");
else printf("Y\n");
}
return 0;
}