遇到一个算法题,接龙的单词,求大神相助!!!

无名鼠辈 2015-12-16 10:08:45
在公司Mala-Offline,人们喜欢玩一个游戏叫做接龙的单词。玩这个游戏,他们定义一组
单词的字典。然后选择任意两个单词从字典表示开始和结束,我们的目标是找到
从开始到结束的所有最短序列(s),比如:
•每次只能改变一个字母
•每个中间单词必须存在于字典

给出:
start = "hlt"
end = "cag"
dict = ["hat","dat","dag","lat","lag"]

返回:
[
["hlt","hat","dat","dag","cag"],
["hlt","hat","lat","lag","cag"]
]
不知道算法应该如何写?求代码。。。
...全文
520 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq_36425552 2018-01-04
  • 打赏
  • 举报
回复
package 乱七八糟程序; import java.util.ArrayList; import java.util.Iterator; import java.util.Scanner; import java.util.TreeSet; /** * Created by LXM on 2017-05-21. */ public class ProgramExam { static ArrayList<ArrayList<EngWord>> finalyRes = new ArrayList<>(); //存放最后所有的接龙 static TreeSet<String> finalyRes2 = new TreeSet<>(); //最长的可能有多条,用这个来存放 public static void main(String[] args) { System.out.println("please input some Word:"); Scanner sc = new Scanner(System.in); String read = sc.nextLine(); String[] eachPath = read.split("\\s+"); //递归 change(eachPath, 0, eachPath.length - 1); //找最长 int max = 0; for (int i = 0; i < finalyRes.size(); i++) { if (finalyRes.get(i).size() > max) max = finalyRes.get(i).size(); } //输出所有最长 for (int i = 0; i < finalyRes.size(); i++) { String tmp = ""; if (finalyRes.get(i).size() == max) { Iterator<EngWord> iterator = finalyRes.get(i).iterator(); while (iterator.hasNext()) { EngWord eng = iterator.next(); tmp += eng.getExp() + " "; } if (!"".equals(tmp)) finalyRes2.add(tmp); } } Iterator<String> iterator = finalyRes2.iterator(); while (iterator.hasNext()) { System.out.println(iterator.next()); } } public static void change(String[] str, int first, int ends) { if (first == ends) { ArrayList<EngWord> arr = new ArrayList<>(); ArrayList<EngWord> res = new ArrayList<>(); for (int i = 0; i < str.length; i++) { char[] tmp = str[i].toCharArray(); char start = tmp[0]; char end = tmp[tmp.length - 1]; EngWord engWord = new EngWord(str[i], start, end); arr.add(engWord); } boolean flag = true; //be eh hi il //轮询 for (int i = 0; i < arr.size(); i++) { res.clear(); EngWord baseWord = arr.get(i); res.add(baseWord); for (int k = 0; k < arr.size(); k++) { for (int j = 0; j < arr.size(); j++) { if (i == j) continue; EngWord secondWord = arr.get(j); if (secondWord.getStart() == res.get(res.size() - 1).getEnd()) { if (!res.contains(secondWord)) { res.add(secondWord); j = 0; } } else { continue; } } } //只有一个的话就不接了 if (res.size() == 1) { continue; } //存下每一个可以接龙的 ArrayList<EngWord> copyArr = (ArrayList<EngWord>) res.clone(); finalyRes.add(copyArr); } } for (int i = first; i <= ends; i++) { swap(str, i, first); change(str, first + 1, ends); //固定好当前一位,继续排列后面的 swap(str, i, first); } } private static void swap(String[] str, int i, int first) { String tmp; tmp = str[first]; str[first] = str[i]; str[i] = tmp; } } class EngWord { String exp; char start; char end; public EngWord(String exp, char s, char e) { this.exp = exp; this.start = s; this.end = e; } public EngWord() { } public String getExp() { return exp; } public void setExp(String exp) { this.exp = exp; } public char getStart() { return start; } public void setStart(char start) { this.start = start; } public char getEnd() { return end; } public void setEnd(char end) { this.end = end; } }
无名鼠辈 2015-12-17
  • 打赏
  • 举报
回复
引用 1 楼 飏飏一蝶的回复:
感觉可以转换成图的最短路径算法之类的
能不能有具体点的代码呢~
ITjavaman 2015-12-17
  • 打赏
  • 举报
回复
语文没学好,表示没看懂
无名鼠辈 2015-12-16
  • 打赏
  • 举报
回复
能不能有具体点的代码呢?
飏飏一蝶 2015-12-16
  • 打赏
  • 举报
回复
感觉可以转换成图的最短路径算法之类的
内容概要:本文档围绕基于H桥级联五电平逆变器的三相LCL滤波器SPWM调制技术,利用MATLAB/Simulink平台开展系统建模与仿真分析,深入探讨多电平逆变器的调制策略、LCL滤波器的设计方法及其在电力电子系统中的应用。文档不仅聚焦于核心仿真模型的构建与性能验证,还系统整理了大量相关科研资源,涵盖VSG控制、双机并联、下垂控制、无功优化、储能配置、微电网调度等多个前沿方向,展示了MATLAB/Simulink在电力系统、新能源控制、信号处理及智能优化等领域的广泛应用。同时强调科研过程中逻辑思维、创新意识与借助优质仿真资源的重要性,倡导“借力”提升科研效率。; 适合人群:电力电子、电气工程、自动化、新能源系统及相关专业的研究生、科研人员及从事电力电子与微电网仿真的工程技术人员。; 使用场景及目标:①开展多电平逆变器与LCL滤波器的仿真设计及性能优化研究;②深入掌握SPWM调制技术及其在逆变系统中的实现机制;③复现高水平论文中的控制策略与仿真模型,支撑科研项目或论文写作;④结合提供的网盘资源快速获取主流研究方向的Matlab/Simulink代码与模型,加速科研进程。; 其他说明:所有仿真资源可通过关注公众号“荔枝科研社”并访问指定百度网盘链接免费获取,建议读者系统学习文档内容并结合自身研究课进行实践与创新,充分发挥资源的参考价值与实用价值。
内容概要:本文聚焦于VSG(虚拟同步发电机)双机并联系统中动态虚拟复阻抗在环流抑制与功率均分方面的关键作用,通过Simulink仿真平台系统性地实现了孤岛微电网环境下多逆变器并联运行的核心控制策略。研究深入探讨了动态虚拟复阻抗的设计原理及其对环流的有效抑制机制,确保有功与无功功率的精确均衡分配,同时涵盖了VSG控制、下垂控制、电压电流双闭环调节及系统稳定性分析等核心技术模块。该仿真模型不仅验证了控制算法在静态条件下的有效性,更着重考察其在负载突变等动态工况下的响应速度、鲁棒性与系统整体稳定性,为微电网的可靠自治运行提供了理论依据与实践参考。; 适合人群:具备电力电子、自动控制理论及微电网相关基础知识,从事电气工程、新能源发电系统、分布式能源控制等领域研究的研发人员及高校研究生。; 使用场景及目标:① 深入理解VSG双机并联系统中环流的产生机理及动态虚拟阻抗的抑制方法;② 掌握动态虚拟复阻抗的设计流程及其在实现功率均分中的核心作用;③ 利用Simulink搭建并调试多逆变器协同控制系统,服务于科研项目开发、高水平论文复现或实际工程方案的前期验证。; 阅读建议:建议结合提供的Simulink仿真模型进行动手实践,重点关注控制器参数(如虚拟阻抗值、PI调节器增益)的整定过程与系统动态响应之间的关系,并推荐参考相关领域的权威文献以深化对VSG先进控制策略的理解与优化能力。
内容概要:本文档介绍了一个基于Simulink的发电机故障暂态仿真模型,旨在深入研究发电机在发生短路、接地等典型故障时电压、电流等关键电气量的动态变化过程。通过建立精确的发电机数学模型,并结合实际故障场景进行建模,利用Simulink平台开展高保真度的暂态仿真分析,全面揭示故障期间系统的瞬态响应特性与演化规律。该模型不仅能够准确模拟电磁暂态过程,还可用于电力系统稳定性评估、继电保护装置的设计与校验、故障诊断与定位等关键技术环节,具有重要的科研价值与工程应用前景。此外,文档还整合了大量电力系统相关仿真资源,涵盖微电网、逆变器控制、储能优化、综合能源系统等多个前沿方向,体现了其在电力系统建模仿真领域的广度与深度。; 适合人群:具备电力系统分析基础理论知识和Simulink仿真操作经验的高校研究生、电力领域科研人员及从事电力设备研发与系统运维的工程技术专家。; 使用场景及目标:①应用于高校课程设计与实验教学,帮助学生直观理解发电机故障机理及暂态过程;②服务于科研项目中对新型保护策略、控制算法或系统稳定性的验证与优化;③为实际工程中发电机保护定值整定、故障应急预案制定及系统安全性评估提供可靠的仿真支撑。; 阅读建议:建议读者结合提供的Simulink模型文件与文档说明同步学习,重点掌握发电机建模假设条件、不同故障类型的设置方法以及仿真结果的分析流程,鼓励通过调整系统参数进行对比实验,以深化对电力系统暂态行为本质的理解。

51,409

社区成员

发帖
与我相关
我的任务
社区描述
Java相关技术讨论
javaspring bootspring cloud 技术论坛(原bbs)
社区管理员
  • Java相关社区
  • 小虚竹
  • 谙忆
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧