[NOIP2000 提高组] 单词接龙

[NOIP2000 提高组] 单词接龙

题目背景

注意:本题为上古 NOIP 原题,不保证存在靠谱的做法能通过该数据范围下的所有数据。

本题为搜索题,本题不接受 hack 数据。关于此类题目的详细内容

NOIP2000 提高组 T3

题目描述

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

输入格式

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

输出格式

只需输出以此字母开头的最长的"龙"的长度。

样例 #1

样例输入 #1

复制代码
5
at
touch
cheat
choose
tact
a

样例输出 #1

复制代码
23

提示

样例解释:连成的"龙"为 atoucheatactactouchoose

n ≤ 20 n \le 20 n≤20。

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

int n,anslen = 0;//anslen答案长度 
string s[20];//字符串数组 
int vis[1000000],k[20][20];
//vis标记数组,k记录每两个字符串间最少的重叠部分 

int csh(string x,string y){
	int l1 = x.length(),l2 = y.length();
	//两个字符串的长度 
	for (int i = 1;i <= min(l1,l2) - 1;i++){
		//从只重叠一个字符开始枚举(受字符串不能有包含关系的影响,要-1) 
		if(x.substr(l1 - i,i) == y.substr(0,i)){
			//找到一个部分相同,返回i(最少重叠部分)的值 
			return i;
		}
	}
	return 0;//说明没有重叠部分,返回0 
}

void dfs(int x,int len){
	anslen = max(len,anslen);//答案便量与len取max 
	for (int i = 1;i <= n;i++){
		if(vis[i] == 2 || k[x][i] == 0){
			continue;
		}//如果此字符串被使用两次 或 没有与当前字符串有重叠部分,直接跳过 
		vis[i]++;//使用次数++ 
		dfs(i,len + s[i].length() - k[x][i]);
		//x -> 当前枚举字符串
		//len -> len加上字符串i的长度再减去重叠部分 
		vis[i]--;//取消标记; 
	}
}

int main(){
	scanf("%d",&n);//字符串个数 
	for (int i = 1;i <= n+1;i++)
		cin>>s[i];
	//输入 
	for (int i = 1;i <= n+1;i++){
		for (int j = 1;j <= n+1;j++){
			k[i][j] = csh(s[i],s[j]);
		}
	}//初始化,字符串i与其它字符串的最少重叠部分 
		
	for (int i = 1;i <=n;i++){
		if(s[n+1][0] != s[i][0]){
			continue;
		}//如果开头与要求字符不一样直接跳过 
		vis[i]++;//此字符串使用一次 
		dfs(i,s[i].length());//进入dfs 
		vis[i]--;//取消标记 
	}
	
	printf("%d",anslen);
	return 0;
}
相关推荐
kyriewen1 分钟前
WebAssembly:前端界的“外挂”,让C++代码在浏览器里跑起来
前端·c++·webassembly
承渊政道1 小时前
【动态规划算法】(完全背包问题从状态定义到空间优化)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
超级大福宝1 小时前
【力扣48. 旋转图像】超好记忆版 + 口诀
c++·算法·leetcode
爱写代码的倒霉蛋1 小时前
2023年天梯赛L1-8
数据结构·算法
lzh200409191 小时前
深入学习Linux进程间通信:共享内存
linux·c++
apollowing1 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(上)
算法·启发式算法·web app
特种加菲猫1 小时前
多态:让代码拥有“千变万化”的能力
开发语言·c++
生物信息与育种1 小时前
黄三文院士领衔植物星球计划(PLANeT)发表Cell
人工智能·深度学习·算法·面试·transformer
aini_lovee2 小时前
WSN 四大经典无需测距定位算法
算法