1172: 单词接龙

时间限制: 1 Sec  内存限制: 128 MB
提交: 12  解决: 5

题目描述

单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”(每个单词都最多在“龙”中出现两次),在两个单词相连时,其重合部分合为一部分,例如 beast和astonish,如果接成一条龙则变为beastonish,另外相邻的两部分不能存在包含关系,例如at 和 atide 间不能相连。

输入

输入的第一行为一个单独的整数n (n<=20)表示单词数,以下n 行每行有一个单词,输入的最后一行为一个单个字符,表示“龙”开头的字母。你可以假定以此字母开头的“龙”一定存在.

输出

只需输出以此字母开头的最长的“龙”的长度

样例输入

5
at
touch
cheat
choose
tact
a

样例输出

23

提示

样例中,连成的“龙”为atoucheatactactouchoose

暴力往下搜索

 #include <iostream>
#include <cstring>
#include <algorithm>
#include <cstdio>
using namespace std;
char ch[][];
int vis[];
int n,Max;
int judge(int x,int y)
{
int i,j;
//cout<<ch[x]<<" "<<ch[y]<<endl;
int len1=strlen(ch[x]);
int len2=strlen(ch[y]);
for(i=len1-;i>=&&(len1-i)<=len2;i--)
{
int k1=i,k2=;
for(;k1<len1;k1++,k2++)
if(ch[x][k1]!=ch[y][k2])
break;
if(k1==len1)
{
if((len1-i)==strlen(ch[y]))
return ;
else
return len1-i;
}
}
return ;
}
void dfs(int f,int sum)
{
int i,j;
if(sum>Max)
Max=sum;
for(i=;i<=n;i++)
{
if(vis[i]>=)
continue;
int ans=judge(f,i);
if(ans!=)
{
vis[i]++;
//cout<<strlen(ch[i])-ans<<endl;
dfs(i,sum+strlen(ch[i])-ans);
vis[i]--;
}
}
return;
}
int main()
{
int i,j;
freopen("in.txt","r",stdin);
while(scanf("%d",&n)!=EOF)
{
Max=;
memset(vis,,sizeof(vis));
for(i=;i<=n;i++)
scanf("%s",ch[i]);
scanf("%s",ch[]);
dfs(,strlen(ch[]));
printf("%d\n",Max);
}
return ;
}

最新文章

  1. (windows)mongoDB3X+Robomongo的安装与基础配置
  2. 使用jquery的append(content)方法的注意事项
  3. 帮你深入理解OAuth2.0协议
  4. cocos run -p android报错 BUILD FAILED ..\ant\build.xml:892
  5. saltstack实战3--配置管理之YAML语法
  6. Git简明教程
  7. ListView多选操作模式——上下文操作模式
  8. 使用扩展名获取mimetype
  9. Ello讲述Haar人脸检测:易懂、很详细、值得围观
  10. 基于Three.js的360度全景--photo-sphere-viewer--简介
  11. iOS 10 适配 ATS
  12. TypeError: value.getTime is not a function (elementUI报错转载 )
  13. Mysql字段名与保留字冲突导致的异常解决
  14. WSL(Windows Subsystem for Linux)的安装与使用及 mongodb安装
  15. Socket网络编程入门
  16. Linux搭建Hadoop集群---Jdk配置
  17. Android开机广播和关机广播
  18. java.net.SocketTimeoutException: Read timed out 错误解决
  19. C# 动态获取代码所在行号
  20. Windows同时安装python3和python2

热门文章

  1. Swift学习之常用UI的使用
  2. MyGeneration 默认设置中没有数据库驱动
  3. (转)Oracle Data Guard配置
  4. android 反编译操作
  5. 计算机语言学习导论[C/C++]
  6. 脱机BT transmission
  7. cf492C Vanya and Exams
  8. openstack组件手动部署整合
  9. for的用法
  10. [RxJS] Reactive Programming - Sharing network requests with shareReplay()