news 2026/3/25 13:04:20

面试题 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/15 9:16:31

4G与4G+路由器:技术与实际体验的差异

4G路由器&#xff0c;作为占据大众主流市场的产品种类之一&#xff0c;随着4G这一概念的普及&#xff0c;会逐渐失去市场吗&#xff1f;也许大家也会疑惑这两者的不同。本文&#xff0c;就从这一角度出发&#xff0c;来和大家聊聊这两种路由器的区别。基础差异4G路由器&#xf…

作者头像 李华
网站建设 2026/3/19 9:15:27

还在盲目冲业绩?亚马逊增长双引擎,先重塑内功再谈破局

亚马逊的竞争已经从流量争夺转向转化效率的深度较量&#xff0c;实现可持续增长&#xff0c;关键在于系统化结合“站内转化内功”与“站外精准引流”&#xff0c;构建自我强化的增长飞轮。一、内功筑基&#xff1a;以用户为中心的Listing重塑Listing优化的核心在于高效“对话”…

作者头像 李华
网站建设 2026/3/18 23:10:23

OpenEuler 等 Linux 系统中运行 Vue 项目的方法

在 OpenEuler 等 Linux 系统中运行 Vue 项目,通常需要经过环境准备、项目部署、启动服务三个步骤。以下是详细操作指南: 一、准备运行环境 Vue 项目依赖 Node.js(包含 npm 包管理器),需先安装: 1. 安装 Node.js 和 npm 方法 1:通过系统包管理器(推荐,适合 OpenEule…

作者头像 李华
网站建设 2026/3/20 18:15:22

35、SharePoint开发:架构、特性与部署全解析

SharePoint开发:架构、特性与部署全解析 1. SharePoint架构与页面创建概述 在SharePoint开发中,我们首先从整体上了解其架构。可以使用SharePoint Designer来创建母版页和网站页面。这里需要区分网站页面和应用程序页面,网站页面更侧重于展示内容,而应用程序页面则提供特…

作者头像 李华
网站建设 2026/3/21 3:38:30

36、SharePoint 打包与部署全解析

SharePoint 打包与部署全解析 1. 引言 在 SharePoint 开发中,单个功能的安装相对简单,但当需要一次性安装多个功能时,就需要一种有效的机制将这些功能组合起来进行打包和部署。SharePoint 解决方案打包就是这样一种机制,它能帮助我们更高效地管理和部署多个功能。 2. Sh…

作者头像 李华
网站建设 2026/3/22 18:07:59

37、深入探究 SharePoint 项目结构与部署

深入探究 SharePoint 项目结构与部署 1. 映射文件夹 在 Visual Studio 的 SharePoint 项目中,映射文件夹是一种非常有用的结构,它能将 Visual Studio 项目中的文件部署到 SharePoint 配置单元下的文件夹中,比如 Program Files\Common Files\Microsoft Shared\web server …

作者头像 李华