洛谷 P1019 单词接龙
时间:2022-07-26
本文章向大家介绍洛谷 P1019 单词接龙,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
题目描述
单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”(每个单词都最多在“龙”中出现两次),在两个单词相连时,其重合部分合为一部分,例如 beast和astonish,如果接成一条龙则变为beastonish,另外相邻的两部分不能存在包含关系,例如at和 atide间不能相连。
这道题需要注意三点:
1.每个单词最多在龙里出现两次
2.不能在龙里出现包含关系
3.可以有重合部分
很明显,第一个要接的单词必须首字母是给出的字母,dfs的入口就是满足这个条件的字符串,答案就是这些字符串去dfs找出的最大值,如何dfs?接下来的单词前一部分必须是上一个已经在龙里面的单词的某个后缀,那就去遍历上一个单词从尾开始找,找到一个字符和要接的单词的开头一样,ok接着找,其中一旦发现有某个字符不一样那就不能接龙,如果都可以就返回新增的长度,不如auto,utoh,随便举个例子,找到一个字符和要接的单词一样的位置是u,新增长度是要接的字符长度减去公共长度4-3=1~
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define rg register ll
string s[25];
ll ans,maxx,vis[25],n;
inline ll com(ll x,ll y)
{
for(rg i=s[x].length()-1;i>=1;i--)
{
if(s[x][i]==s[y][0])
{
ll ans=0;
for(rg j=i+1;j<=s[x].length()-1;j++)
{
if(s[x][j]!=s[y][++ans])return 0;
}
return s[y].length()-ans-1;
}
}
return 0;
}
inline void dfs(ll x)
{
for(rg i=1;i<=n;i++)
{
if(vis[i]<2&&com(x,i))
{
ans+=com(x,i);
vis[i]++;
dfs(i);//回溯
vis[i]--;
ans-=com(x,i);
}
}
//cout<<ans<<endl;
maxx=max(maxx,ans);
}
int main()
{
cin>>n;
for(rg i=1;i<=n;i++)cin>>s[i];
getchar();
char ch;
cin>>ch;
for(rg i=1;i<=n;i++)
{
if(s[i][0]==ch)
{
ans=s[i].length();
vis[i]++;
dfs(i);
vis[i]--;
maxx=max(maxx,ans);
//cout<<maxx<<endl;
}
}
cout<<maxx<<endl;
//while(1)getchar();
return 0;
}
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Codeforces Round #622 (Div. 2)A~~C1
- AtCoder Beginner Contest 156 A~~D
- AtCoder Beginner Contest 155
- Codeforces Round #620 (Div. 2) A~~D
- DFS+记忆化搜索 -- 简单练习
- AtCoder Beginner Contest 154
- map + pair用法练习
- 蛇形矩阵
- 【SpringBoot WebFlux 系列】 header 参数解析
- URL 去重的 6 种方案!(附详细实现代码)
- 原生JS封装拖动验证滑块你会吗?
- 企业远程视频会议云服务EasyRTC-SFU版本支持 https 功能设计逻辑
- python之编码解码、字符串常用方法
- python之列表
- 一文带你深入理解Mysql索引底层数据结构与算法