news 2026/4/18 11:28:24

面试题 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/4/18 10:51:07

告别 Win10 服务器开机漫长 fix!系统盘必检 + 外挂盘精准跳过实操全攻略

在 Win10 服务器运维中,外接大容量硬盘(如 3.9T 存储盘)是常见操作,但每次开机触发自动磁盘检查(fix,即 chkdsk),动辄耗时数小时甚至卡死,不仅拖慢开机效率,还暗藏硬盘与系统损坏风险。本文聚焦核心需求 ——只让系统盘执行开机检查,彻底跳过外挂盘,同时详解已触发…

作者头像 李华
网站建设 2026/4/18 8:03:31

38、可配置部署与自定义部署步骤详解

可配置部署与自定义部署步骤详解 1. 可配置部署概述 可配置部署助力我们在 Visual Studio 中完成 SharePoint 项目的部署与撤回操作。Visual Studio 2010 自带两种部署配置:默认部署和无激活部署。 部署配置由部署和撤回两部分构成,每部分都由一系列步骤组成,且这些步骤可…

作者头像 李华
网站建设 2026/4/17 11:07:55

阿里云渠道商:在更换阿里云 GPU 公网 IP 时,如何确保数据的安全性?

一、引言在云计算运维中&#xff0c;GPU 实例常承载 AI 训练、图像渲染等关键任务。当需要更换公网 IP 时&#xff08;如 IP 被封禁或业务迁移&#xff09;&#xff0c;数据安全成为首要考量。本文将系统化解析阿里云 GPU 实例更换公网 IP 时的核心防护策略。二、数据安全三重保…

作者头像 李华
网站建设 2026/4/18 8:44:29

算力之重:AI飞速狂奔背后,被忽视的真实代价

当我们惊叹于 AI 一次次刷新认知边界时&#xff0c;很少有人停下来问一句&#xff1a; 这些“智能”&#xff0c;究竟有多重&#xff1f;答案是——算力之重。从一次简单的文本生成&#xff0c;到一个大模型的训练完成&#xff0c;背后是成千上万张 GPU 日夜运转&#xff0c;是…

作者头像 李华
网站建设 2026/4/18 4:03:08

P2TR :比特币的「终极脚本方案」与比特鹰的技术解析

作者&#xff1a;比特鹰霸王龙 引言 比特鹰为你总结如下&#xff0c;P2TR&#xff08;Pay To Taproot&#xff09;是一种先进的比特币锁定脚本&#xff0c;它将简单的公钥支付&#xff08;P2WPKH&#xff09;和更复杂的自定义脚本支付&#xff08;P2WSH&#xff09;融合为一种更…

作者头像 李华