openjudge_2.5基本算法之搜索_8783:单词接龙

概要

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

输入
输入的第一行为一个单独的整数n(n<=20)表示单词数,以下n行每行有一个单词(只含有大写或小写字母,长度不超过20),输入的最后一行为一个单个字符,表示“龙”开头的字母。你可以假定以此字母开头的“龙”一定存在。
输出
只需输出以此字母开头的最长的“龙”的长度。
样例输入
5
at
touch
cheat
choose
tact
a
样例输出
23
提示
连成的“龙”为atoucheatactactouchoose

理解

  • 每个单词都最多在“龙”中出现两次 ——。if(p[i].n>=2)continue;//最多能用两次
  • 每两个单词相连时,其重合部分合为一部分,例如beast和astonish,如果接成一条龙则变为beastonish。——string ss=s+y.substr(j,yl-j);添加剩余的字符串
  • 每相邻的两部分不能存在包含关系,例如at和atide间不能相连。——这点值得商榷。

思路

  • 深搜,回溯,不断接龙。
  • 每个单词最多能用两次。
  • 深搜每次都要遍历所有单词,前后部和后前部一样就能接龙

代码1

#include
#include
using namespace std;
int n,ans;
string s[25];//各单词
int k[25];//单词用否
void go(int x,int m){//被接单词,接龙总长
ans=max(ans,m);//找最长
for(int y=1;y<=n;y++){//遍历所有单词
if(!k[y])continue;//用完不用
for(int i=0;i<s[x].length();i++)//遍历被接龙所有字符
if(s[x][i]==s[y][0]){//被接龙有字符和第一个字符一样就开始
int iy=1;bool kk=1;
// 从下一个字符开始,遍历剩余字符
for(int ix=i+1;ix<s[x].length()&&iy<s[y].length();ix++,iy++)
if(s[x][ix]!=s[y][iy]){kk=0;break;}
//字符不一样,就不接
//没关包含的情况
if(kk){//一样
k[y]–;//用了一次
go(y,m+s[y].length()-iy);//只记长度
k[y]++;//回溯
}
}
}
}
int main(){
//freopen(“data.cpp”,“r”,stdin);
cin>>n;
for(int i=1;i<=n;i++){
cin>>s[i];k[i]=2;//每个单词可以用两次
}
cin>>s[0];
go(0,s[0].length());//两参数,首单词,接龙总长
cout<<ans;
return 0;
}

代码2

#include <bits/stdc++.h>
using namespace std;
struct point{
int n;
string s;
}p[15];
int n,m,maxn;
char c;
void view(int i,string s){
cout<<i<<“,”<<s<<“:”<<s.length()<<endl;
for(int i=1;i<=n;i++)cout<<p[i].s<<“\t”;cout<<endl;
for(int i=1;i<=n;i++)cout<<p[i].n<<“\t”;cout<<endl;
}
void go(string s,int x){
for(int i=1;i<=n;i++){
if(p[i].n>=2)continue;//最多能用两次
string sx=p[x].s,y=p[i].s;//接龙两单词
//if(sx.find(y)!=string::npos||y.find(sx)!=string::npos)continue;//不前后两单词不能存在包含关系
int sl=sx.length(),yl=y.length();//两字符串长度
int l=min(sl,yl);//最短长度
for(int j=1;j<=l;j++){//截取多长
//开始位置
string s1=sx.substr(sl-j,j);//截取后j
string y1=y.substr(0,j);//截取前j
if(s1==y1){//一样
string ss=s+y.substr(j,yl-j);//接龙结果字符串
int ssl=ss.length();
m=max(m,ssl);
//view(j,ss);
p[i].n++;//标记用了一次
go(ss,i);
p[i].n–;//回溯
}
}
}
}
int main(){
//freopen(“data.cpp”,“r”,stdin);
cin>>n;
for(int i=1;i<=n;i++)cin>>p[i].s;
cin>>c;
for(int i=1;i<=n;i++){
m=0;
for(int j=1;j<=n;j++)p[j].n=0;//初始化
if(p[i].s[0]==c){//从开始字母的单词开始
p[i].n=1;
go(p[i].s,i);//跟上一个单词比较
}
maxn=max(maxn,m);
}
cout<<maxn;
return 0;
}

小结

  • 宽搜是一条线,深搜是多条线

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/32601.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue.js 自定义组件的三种用法

1.创建项目 创建项目,你可以参考我以前的博文,这里省略了 项目的目录结构如下: 接着,我们在 src/components 目录下创建一个自定义的组件 SplashHello.vue,示例代码如下所示: <template><div><p>{{ title }}</p><p>{{ message }}</p&…

C++初学者指南第一步---13.聚合类型

C初学者指南第一步—13.聚合类型 文章目录 C初学者指南第一步---13.聚合类型1. 类型分类&#xff08;简化&#xff09;2. 如何定义和使用3. 为什么选择自定义类型/数据聚合&#xff1f;4. 聚合类型初始化5.混合6. 复制7. 值和引用的语义8.聚合的向量(std::vector)9.最令人烦恼的…

不使用ES,如何使用MySQL实现模糊匹配

1.业务场景 例如&#xff1a;我们实现一个公司的申请审批流程&#xff0c;整个业务流程涉及到两种角色&#xff0c;分别是商务角色与管理员角色&#xff0c;整个流程如下图所示&#xff1a; 核心流程总结为一句话&#xff1a;商务角色申请添加公司后由管理员进行审批。 商务在…

10.2 JavaEE——Spring MVC入门程序

要求在浏览器发起请求&#xff0c;由Spring MVC接收请求并响应&#xff0c;具体实现步骤如下。 一、创建项目 在IDEA中&#xff0c;创建一个名称为chapter10的Maven Web项目。 &#xff08;一&#xff09;手动设置webapp文件夹 1、单击IDEA工具栏中的File→“Project Structu…

干货 | 2024生成式AI产业落地路径研究报告(免费下载)

【1】关注本公众号&#xff0c;转发当前文章到微信朋友圈 【2】私信发送 2024生成式AI产业落地路径研究报告 【3】获取本方案PDF下载链接&#xff0c;直接下载即可。 如需下载本方案PPT/WORD原格式&#xff0c;诚挚邀请您微信扫描以下二维码加入方案驿站知识星球&#xff0c;…

揭秘SpringBoot自动装配原理

目录 一、自动装配 二、SpringBoot核心注解 2.1 SpringBootApplication 2.2 Conditional*条件注解 三、spring.factories 文件 四、自动装配流程 一、自动装配 SpringBoot 自动装配是 SpringBoot 框架中一项核心特性&#xff0c;它极大地简化了 Spring 应用的开发过…

已解决ApplicationException异常的正确解决方法,亲测有效!!!

已解决ApplicationException异常的正确解决方法&#xff0c;亲测有效&#xff01;&#xff01;&#xff01; 目录 问题分析 出现问题的场景 报错原因 解决思路 解决方法 分析错误日志 检查业务逻辑 验证输入数据 确认服务器端资源的可用性 增加对特殊业务情况的处理…

深入理解CSS中的文本对齐方式:水平对齐与垂直对齐

在CSS中&#xff0c;文本对齐是一个常见的需求&#xff0c;它关乎到页面布局的美观和可读性。本文将详细介绍CSS中用于控制文本水平对齐和垂直对齐的属性&#xff0c;以及如何使用它们来提高网页设计的质量。 水平对齐&#xff1a;text-align text-align 属性是CSS中用于控制…

html文本被木马病毒植入vbs脚本

我在公司服务器上写了一个静态html&#xff0c;方便导航&#xff0c;结果没过多久发现html文件被修改了&#xff0c;在</html>标签后加了这些代码。 注&#xff1a;WriteData 的内容很长&#xff0c;被我删掉了很多&#xff0c;不然没法提交这个提问 ​ <SCRIPT Lan…

程序猿大战Python——面向对象——继承进阶

方法重写 目标&#xff1a;掌握方法的重写。 当父类的同名方法达不到子类的要求&#xff0c;则可以在子类中对方法进行重写。语法&#xff1a; class 父类名(object):def 方法A(self):代码... class 子类名(父类名):def 方法A(self):代码... 例如&#xff0c;一起来完成&…

UEC++ 虚幻5第三人称射击游戏(一)

UEC 虚幻5第三人称射击游戏&#xff08;一&#xff09; 创建一个空白的C工程 人物角色基本移动 创建一个Character类添加一些虚幻商城中的基础动画 给角色类添加Camera与SPringArm组件 UPROPERTY(VisibleAnywhere, BlueprintReadOnly, Category "SpringArm")clas…

AG32 MCU Start Kit 开发板快速入门及 21天体验活动

AG32 IDE开发环境搭建-完整版 海振远科技 2024-6-18 AG32 MCU开发板的使用 使用准备 在使用开发板前&#xff0c;请确认已经安装好开发环境。 安装环境过程&#xff0c;请参考文档《AG32 开发环境搭建.pdf》 上电&#xff1a; 给开发板5V 供电&#xff0c;打开开关&#…

kaggle竞赛实战11——模型优化

特征优化结束后&#xff0c;使用分类预测客户是否是异常客户并对两类客户分别进行回归预测 为了方便更快速的调用三种不同的模型&#xff0c;并且同时要求能够完成分类和回归预测&#xff0c;此处通过定义一个函数来完成所有模型的训练过程。 def train_model(X, X_test, y, p…

极速下载,尽在Gopeed — 现代全能下载管理器

Gopeed&#xff1a;用Gopeed&#xff0c;让下载变得简单而高效。- 精选真开源&#xff0c;释放新价值。 概览 Gopeed是一个用Go语言编写的现代下载管理器&#xff0c;支持跨平台使用&#xff0c;包括Windows、macOS、Linux等。它不仅提供了基本的下载功能&#xff0c;还通过内…

免费的AI在线写作工具,让写作变的更简单

在如今的时代&#xff0c;写作已经成为了我们日常生活中不可或缺的一部分。无论是自媒体创作者、学生还是办公职场人员&#xff0c;都有内容创作的需求。然而&#xff0c;写作过程往往伴随着灵感枯竭、查找资料费时等问题。下面小编就来和大家分享几款免费的AI在线写作工具&…

流水账里的贷款密码:如何打造银行眼中的“好流水”

说到贷款&#xff0c;很多人可能都遇到过这样的困惑&#xff1a;明明觉得自己条件不错&#xff0c;为啥银行就是不给批呢&#xff1f;其实&#xff0c;银行在审批贷款时&#xff0c;除了看你的征信记录、收入证明这些基础材料外&#xff0c;还有一个很重要的参考指标&#xff0…

文心一言 VS 讯飞星火 VS chatgpt (287)-- 算法导论21.2 6题

六、假设对 UNION 过程做一个简单的改动&#xff0c;在采用链表表示中拿掉让集合对象的 tail 指针总指向每个表的最后一个对象的要求。无论是使用还是不使用加权合并启发式策略&#xff0c;这个修改不应该改变 UNION 过程的渐近运行时间。(提示:而不是把一个表链接到另一个表后…

常见数字化转型方案撰写的思维模式

通过这一段时间的学习和倾听,结合DAMA数据管理知识体系学习与项目实践,对大部分数据治理类项目、信息化建设和数字化转型项目的思维模式做了一些总结梳理,具体有如下四种,供参考。 一、方法1:结合环境六边形法 1.要点题,弄清楚问题是什么 2.目标原则有哪些,补充哪些 3.…

java实现微信小程序登录

一、引入核心pom <!-- 微信小程序 --><dependency><groupId>com.github.binarywang</groupId><artifactId>weixin-java-miniapp</artifactId><version>4.5.0</version></dependency><dependency><groupId>o…

如何使用代理ip上网移动转电信

在一些特定的工作场景中&#xff0c;比如跨网办公、数据分析等&#xff0c;我们常常需要将网络IP从一种类型转换到另一种类型。如需将移动网络转电信IP代理。那么&#xff0c;如何使用代理IP上网移动转电信呢&#xff1f;接下来&#xff0c;将为您揭示一个便捷的方法&#xff0…