news 2026/4/9 1:47:47

面试题 17.15. 最长单词

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
面试题 17.15. 最长单词

题目描述

给定一组单词words,编写一个程序,找出其中的最长单词,且该单词由这组单词中的其他单词组合而成。若有多个长度相同的结果,返回其中字典序最小的一项,若没有符合要求的单词则返回空字符串。

示例:

输入:["cat","banana","dog","nana","walk","walker","dogwalker"]输出:"dogwalker"解释:"dogwalker"可由"dog"和"walker"组成。

代码实现

import java.util.*; class Solution { public String longestWord(String[] words) { // 按长度分组 Map<Integer, List<String>> map = new HashMap<>(); Set<String> set = new HashSet<>(); int maxL = 0; for (String s : words) { set.add(s); int k = s.length(); map.computeIfAbsent(k, key -> new ArrayList<>()).add(s); maxL = Math.max(maxL, k); } // 从最长到最短检查 while (maxL > 0) { if (map.containsKey(maxL)) { List<String> list = map.get(maxL); Collections.sort(list); // 字典序排序 for (String s : list) { set.remove(s); // 先移除当前单词 if (canBeFormed(s, set)) { return s; } set.add(s); // 恢复 } } maxL--; } return ""; } private boolean canBeFormed(String word, Set<String> dict) { if (word.isEmpty()) return false; boolean[] dp = new boolean[word.length() + 1]; dp[0] = true; for (int i = 1; i <= word.length(); i++) { for (int j = 0; j < i; j++) { if (dp[j] && dict.contains(word.substring(j, i))) { dp[i] = true; break; } } } return dp[word.length()]; } }

class Solution { public String longestWord(String[] words) { // 1. 对单词数组进行排序 // 规则:优先按长度降序排列(从长到短),长度相同时按字典序升序排列 Arrays.sort(words, (o1, o2) -> { if (o1.length() == o2.length()) // 长度相同时,按字典序升序排列(a在前,z在后) return o1.compareTo(o2); else { // 长度不同时,按长度降序排列(长在前,短在后) return Integer.compare(o2.length(), o1.length()); } }); // 2. 创建HashSet存储所有单词,便于快速查找 Set<String> set = new HashSet<>(Arrays.asList(words)); // 3. 遍历排序后的单词数组 // 由于已经按长度降序、字典序升序排序,找到的第一个符合条件的单词就是答案 for (String word : words) { // 3.1 先将当前单词从集合中移除,确保不会使用单词本身来构造自己 set.remove(word); // 3.2 检查当前单词是否能由集合中的其他单词组成 if (find(set, word)) return word; // 找到符合条件的单词,直接返回 // 3.3 恢复集合,准备检查下一个单词 set.add(word); } // 4. 没有找到符合条件的单词,返回空字符串 return ""; } // 递归方法:判断给定的单词是否能由字典(set)中的单词组成 public boolean find(Set<String> set, String word) { // 基线条件:如果单词长度为0,说明已经成功匹配完成 if (word.length() == 0) return true; // 尝试所有可能的分割点 for (int i = 0; i < word.length(); i++) { // 将单词分为两部分:word[0...i] 和 word[i+1...end] String prefix = word.substring(0, i + 1); // 如果前缀存在于字典中,并且剩余部分也能由字典中的单词组成 if (set.contains(prefix) && find(set, word.substring(i + 1))) return true; // 找到一种有效的分割方式 } // 所有分割方式都尝试过了,无法组成该单词 return false; } }

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/27 16:25:37

寻找最优解:用“双核四驱”体系评估关键GEO服务商推荐

当生成式AI搜索成为用户获取信息的核心入口&#xff0c;“被AI看见并推荐”已成为品牌无法回避的战略议题。面对市场上众多的服务商&#xff0c;一份有价值的“geo服务商推荐”清单&#xff0c;不应是简单的公司罗列&#xff0c;而必须回答一个根本问题&#xff1a;在技术日新月…

作者头像 李华
网站建设 2026/3/31 22:02:09

基于MPC的换道五次多项式换道:Simulink与CarSim联合仿真之旅

基于mpc的换道五次多项式换道 simulink和carsim联合仿真 有详细的说明文档在自动驾驶领域&#xff0c;换道决策与轨迹规划是核心技术之一。今天咱们来聊聊基于模型预测控制&#xff08;MPC&#xff09;结合五次多项式换道方法&#xff0c;并通过Simulink和CarSim进行联合仿真…

作者头像 李华
网站建设 2026/4/3 18:54:02

SAP 自动清帐的后台配置及其应用

自动清帐的的事务码F.13&#xff0c;想要自动清帐就先要把自动清帐的配置做好。一、自动清账的后台配置事务码&#xff1a;OB74 路径&#xff1a;SPRO-->财务会计&#xff08;新&#xff09;-->总帐会计核算&#xff08;新&#xff09;-->业务交易-->未结清项目的结…

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

基于脱敏算法的综合医疗信息管理系统的设计与实现开题报告

2025届本科生毕业论文&#xff08;设计、创作&#xff09;开题报告论文&#xff08;设计、创作&#xff09;题目基于所在学院、专 业学生姓名学 号本课题研究意义随着信息技术的飞速发展和医疗改革的不断深入&#xff0c;医院管理面临着前所未有的挑战与机遇。传统的医院管理…

作者头像 李华
网站建设 2026/4/5 5:31:06

研究生必备:论文公式格式要求全攻略(附规范示例)

如果你是正在熬夜赶Deadline的毕业生… 凌晨两点的实验室灯光依旧刺眼&#xff0c;你盯着屏幕上密密麻麻的公式&#xff0c;一边被导师催促“尽快定稿”&#xff0c;一边担心知网查重的高昂费用会让本就紧张的生活雪上加霜——这种焦虑&#xff0c;几乎每个面临毕业的研究生都…

作者头像 李华
网站建设 2026/4/9 0:02:10

AI写论文包过工具!5款AI论文生成工具,一键生成初

写学术论文时&#xff0c;总被各种问题困扰&#xff1a;论文构思没思路&#xff0c;论文资料收集耗时长&#xff0c;搭建论文框架怕逻辑不连贯&#xff0c;写完论文还要反复调论文格式、应对论文查重&#xff0c;整套流程又费精力、效率还低。其实不用这么麻烦&#xff0c;选对…

作者头像 李华