news 2026/6/10 16:56:04

DFS -- 1

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
DFS -- 1

P1019 [NOIP 2000 提高组] 单词接龙

https://www.luogu.com.cn/problem/P1019

来发题解的

首先看题目会觉得很简单,但是要怎么用代码实现呢。

字符串这个东西本质其实和数组差不多,只要我们掌握一些语法和函数

substr(x,y)

这是一个可以取出字符串任意一个部分的函数

第一个参数 x -- 代表要截字符串的起始位置

第二个参数 y -- 代表要截字符串的长度

比如 t = 'string' , t.substr(0,2) 就是 st

还有一个用法,比如 substr(4) 就是 ng //从位置4开始到结尾的子字符串

//字符串默认是从0开始索引的

有了这个函数,这个题目就会简单很多,接下来我们继续思考

1.怎么找到对应相等的部分,并接起来

2.怎么递归,要传递什么参数下去,即怎么去dfs。

----首先我们要先找到龙头,即第一个字母的对应,这样才会进行dfs

这很简单,我们只需一个for循环的判断即可。

然后进行匹配,当找到两个字符串相对应的两个部分,就把加起来,再进行dfs

#include<bits/stdc++.h> using namespace std; #define int long long #define endl '\n' const int N = 39; int n,ans = 0; char c; string ss[N]; int v[N] = {0}; void dfs(string s){ int ank = s.size(); ans = max(ans,ank); for(int i = 1 ; i <= n ; i++){ if(v[i] == 2) continue; //每个字符串最多只能被用一次 for(int j = 1 ; j <= min(s.size(),ss[i].size()) ; j++){ if(s.substr(s.size() - j) == ss[i].substr(0,j)){ v[i] ++; dfs(s + ss[i].substr(j));//把后面不相等的部分给接上 v[i] --; } } } } void solve(){ cin>>n; for(int i = 1 ; i <= n ; i++) cin>>ss[i]; cin>>c; for(int i = 1 ; i<= n ; i++){ if(ss[i][0] == c){ v[i] ++; dfs(ss[i]); v[i]--; // 回溯 } } cout<<ans; } signed main() { ios::sync_with_stdio(0); cin.tie(0); int t = 1; //cin >> t; while (t--) { solve(); } return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 11:45:54

我发现流末尾数据丢失,后来才知道重写_transform的flush方法

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 目录Node.js&#xff1a;从“Hello World”到“Hello Bug”的血泪史 一、Node.js到底是个啥玩意儿&#xff1f; 二、安装Node.js…

作者头像 李华
网站建设 2026/6/10 11:21:14

【计算机毕业设计案例】基于springboot的课程互助学习系统“资源共享 - 协作学习 - 互助答疑(程序+文档+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/10 11:19:55

计算机Java毕设实战-基于Java的网上宠物店管理系统宠物食品、用品、活体等)【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/10 12:53:46

扔掉了本地开发环境,然后开发效率翻了一倍

我曾一度坚信&#xff0c;一个精心配置、插件齐全的本地开发环境&#xff0c;是程序员最后的尊严。直到上周&#xff0c;团队新来一个同事&#xff0c;光是配一个项目的开发环境就折腾了整整一天&#xff0c;最后还是因为一个依赖版本问题无法启动。那一刻我突然意识到&#xf…

作者头像 李华
网站建设 2026/6/10 10:51:39

如何复现论文中的大模型方法并解决实际问题

关键词&#xff1a;人工智能大模型 人工智能培训 大模型培训 具身智能培训 智能体 VLA 将论文中的大模型方法应用于实际问题&#xff0c;是一个从“理论”到“实践”的转化过程。以下是系统化的步骤和建议&#xff0c;帮助你高效地实现这一目标&#xff1a; 一、理解论文方法的…

作者头像 李华