IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 【DFS】单词接龙 -> 正文阅读

[数据结构与算法]【DFS】单词接龙

  • 博客主页: https://blog.csdn.net/qq_50285142
  • 欢迎点赞👍收藏?关注?留言 📝 如有错误,敬请指正
  • 🎈虽然生活很难,但我们也要一直走下去🎈

原题链接

思路:
f [ i ] [ j ] f[i][j] f[i][j]数组表示第i个单词和第j个单词能重合的字母数(前后缀匹配的位数)
u s e d [ i ] used[i] used[i]表示第i个单词使用的次数
d f s ( ) dfs() dfs()中参数的含义 :
s s s :代表已经拼接好的字符串
c u r cur cur:表示当前拼接好的字符串的末尾用到的是第 c u r cur cur个单词

首先对所有的单词两两求一下两个单词拼接在一起的前后缀匹配的长度。
之后dfs每次单词匹配时记录一下单词使用的次数,当单词使用的次数小于2时,且前后缀有匹配长度且没有包含关系时可以拼接下一个单词,每个字符串对能够拼接的所有的单词进行dfs
注意dfs之后需要将单词使用的次数回溯一下,就是把单词的使用次数减回去

#include<bits/stdc++.h>
#define fi first
#define se second
using namespace std;
typedef long long ll;
typedef vector<int>vi;
typedef pair<int,int> pii;

const int dx[] = {-1,-2,-2,-1,1,2,2,1};
const int dy[] = {-2,-1,1,2,2,1,-1,-2};
const int N = 1e5+5,M = 1e5+5;
int n,m,k,res;
string word[25];
int f[25][25],used[25];


void dfs(string s,int cur)
{
	res = max(res,(int)s.size());
	used[cur] ++ ;
	
	for(int i=1;i<=n;i++)
	{
		if(f[cur][i] && used[i]<2)
			dfs(s + word[i].substr(f[cur][i]),i);
	}
	used[cur] --;
	
}

void solve()
{
	cin>>n;
	for(int i=1;i<=n;i++)
		cin>>word[i];
	char st;
	cin>>st;
	
	for(int i=1;i<=n;i++)
		for(int j=1;j<=n;j++)
		{
			string a = word[i],b = word[j];
			int sz = min(a.size(),b.size());
			for(int k=1;k<sz;k++)
			{
				if(a.substr(a.size()-k,k)==b.substr(0,k))
				{
					f[i][j] = k;
					break;
				}
			}
		}
	
	for(int i=1;i<=n;i++)
		if(word[i][0]==st)
			dfs(word[i],i);
	cout<<res<<'\n'; 
}

int main()
{
//	ios::sync_with_stdio(false);
//	cin.tie(0),cout.tie(0);
	int _;
//	cin>>_;
	_ = 1;
	while(_--)
	{
		solve();
	 } 
	return 0;
 } 

往期优质文章推荐

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-10-26 12:25:59  更:2021-10-26 12:28:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 4:47:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码