news 2026/6/15 21:26:46

面试题 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/6/15 15:34:21

step-audio-2 全场景接入实战手册:从配置到落地

一、前言&#xff1a;step-audio-2 接入价值与文档定位 step-audio-2 作为专注于音频生成、音频理解与音频编辑的AI模型&#xff0c;凭借高精度的音频生成还原度、全格式音频的解析与处理能力、兼容全生态工具的特性&#xff0c;成为企业级音频业务智能化升级的热门选型。本文将…

作者头像 李华
网站建设 2026/6/15 19:29:54

2025年黑客盗走35亿美元:Synbo解读加密货币最危险的真相

如果有一天&#xff0c;你打开加密钱包&#xff0c;发现资产不是下跌&#xff0c;而是直接被转走了&#xff0c;你第一反应会是什么&#xff1f;很多人会下意识觉得&#xff0c;这种事不会发生在自己身上&#xff0c;或者只是个别项目“倒霉”。但说实话&#xff0c;到了今天&a…

作者头像 李华
网站建设 2026/6/15 2:06:14

GPT进化论:大模型语言与AI的迭代差异及未来应用场景解析!

一、大模型语言与AI 什么是大模型语言&#xff1f; 大模型语言是指使用深度学习技术构建的大型语言模型。这些模型通常具有数十亿甚至千亿级别的参数&#xff0c;能够理解和生成自然语言文本。大模型语言的核心是Transformer架构&#xff0c;它通过自注意力机制和多层神经网络…

作者头像 李华
网站建设 2026/6/15 15:26:59

API测试进阶:基于契约测试(Pact)保障微服务间数据一致性的完整方案

微服务架构下的数据一致性挑战与契约测试的崛起 随着微服务架构的普及&#xff0c;系统间的交互从单体内部的函数调用转变为跨网络、跨进程的API通信。这种松耦合带来了可扩展性与灵活性的同时&#xff0c;也引入了新的测试复杂度&#xff1a;如何确保服务提供者&#xff08;P…

作者头像 李华
网站建设 2026/6/14 14:43:41

C8精准识人:为什么优秀的员工,是不需要管的

在企业管理中&#xff0c;有一句广为流传的话&#xff1a;"真正优秀的员工&#xff0c;是不需要管的。"这句话背后蕴含着深刻的管理智慧——当企业能够精准识别并招聘到与岗位高度匹配的人才时&#xff0c;这些人才会自然展现出自我驱动、自我管理的能力&#xff0c;…

作者头像 李华
网站建设 2026/6/15 16:31:57

腾讯云渠道商:如何快速配置腾讯云轻量应用服务器 Windows 实例?

引言&#xff1a;在数字化转型浪潮中&#xff0c;中小企业上云正面临着一个核心矛盾&#xff1a;有限的IT预算与不断增长的技术需求之间的冲突。据统计&#xff0c;超过60%的中小企业因担忧云服务配置复杂而推迟上云计划&#xff0c;40%的企业在传统IDC向云迁移过程中遭遇配置时…

作者头像 李华