LeetCode-HashMap-748.Shortest Completing Word

2023-10-18 21:59

本文主要是介绍LeetCode-HashMap-748.Shortest Completing Word,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本打算LeetCode一刷结束后,借阅大神的答案二刷再处理文博文,但这道题提交了5次才对,期间有不少粗心的地方,写出来长点记性。

1. 题干:

https://leetcode.com/problems/shortest-completing-word/description/
给出一系列单词(String[] words),以及一个参照(letter)。找出一个最短的单词,该单词包含参照中所有字母【注意,仅仅是字母】
忽略大小写
允许重复
这里写图片描述

2.版本一的思路:

  1. 字符串筛选出字母,全改为小写
  2. 字符串数组按长短排序
  3. 将单词的字符存入哈希表,然后进行匹配比较
  4. 注意大小写、允许重复、删除问题、使用数组其实思路简单【题分类为哈希表,没写数组的,不知道哪个效率高,总之我认为此版本效率一般吧】

错误:
1. 第一次用了不稳定的选择排序
2. 第二次冒泡的第二层-2,第一第二都应该-1才对
3.
这里写图片描述

原因:num计数器位置不对,删除不成功。应该放置在迭代器后,也就是说每次都应该重置为0
4.
这里写图片描述

原因:置为0后再依次加1导致的,删除不成功(yes中,第一次成功删除e,第二次想在下标为1处删除s,显然失败)
解决办法:替换——匹配到的所有字符,都替换为空格,因为信中数字已经剔除干净

代码

package HashTable;import java.util.HashMap;
import java.util.Iterator;/*** @author 王海[https://github.com/AtTops]* @package HashTable* @description* @Date 2018/2/22 10:42* @Version V1.0*/
public class ShortestCompletWord {public static String shortestCompletingWord(String licensePlate, String[] words) {
//        1. 去掉所有非字母字符并转小写String letter = licensePlate.replaceAll("[^a-z^A-Z]", "").toLowerCase();
//        char[] chars = doSomething.toCharArray();
//        Arrays.sort(chars);
//        String letter = chars.toString();//        2. 字符串数组按长短排序(选择排序可能会改变相同长度的单词的出现顺序,这里不能用不稳定排序)String temp;
//        选择排序:错误
/*        for (int i = 0; i < words.length; i++) {for (int j = i + 1; j < words.length; j++) {if (words[i].length() > words[j].length()) {temp = words[i];words[i] = words[j];words[j] = temp;}}}*/
//      冒泡:小的往上int n = words.length;for (int i = 0; i < n - 1; i++) {for (int j = 0; j < n - 1; j++) {if (words[j].length() > words[j+1].length()) {temp = words[j];words[j] = words[j+1];words[j+1] = temp;}}}for (int i = 0; i < words.length; i++) {System.out.println(words[i]);
//                如果比验证信短,则无需继续本次循环了if (words[i].length() < letter.length()) {continue;}String lowerWord = words[i].toLowerCase();//        3. 将单词字符存入哈希表HashMap<Integer, Character> wordMap = new HashMap<>(4, 1);for (int j = 0; j < lowerWord.length(); j++) {wordMap.put(j, lowerWord.charAt(j));}
//          4. 返回第一个包含信所有字符的单词int count = 0;for (int k = 0; k < letter.length(); k++) {if (!wordMap.containsValue(letter.charAt(k))) {break;}
/*for (int m = 0; m < wordMap.size(); k++){if (wordMap.get(m).equals(letter.charAt(k))) {
//                    删除该匹配成功的字符,因为可能需要多个该字符(所以使用containsValue会比较麻烦)wordMap.replace(num, ' ');count++;break;}}*/Iterator itor = wordMap.values().iterator();int num = 0;while (itor.hasNext()) {if ((char) itor.next() == letter.charAt(k)) {
//                    替换该匹配成功的字符,因为可能需要多个该字符wordMap.replace(num, ' ');count++;break;} else {num++;}}}if (count == letter.length()) {return words[i];}}return "Oh no! SomeThing wrong!!!";}public static void main(String[] args) {
//        String[] words = {"s", "sFsfa", "ssF","sFs", "asf", "ssss"};
//        String result = shortestCompletingWord(" sSfa5552 ", words);String[] words = {"yes","less","see"};String result = shortestCompletingWord("ESs69865", words);System.out.println(result);}
}

这篇关于LeetCode-HashMap-748.Shortest Completing Word的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/235372

相关文章

Python轻松实现Word到Markdown的转换

《Python轻松实现Word到Markdown的转换》在文档管理、内容发布等场景中,将Word转换为Markdown格式是常见需求,本文将介绍如何使用FreeSpire.DocforPython实现... 目录一、工具简介二、核心转换实现1. 基础单文件转换2. 批量转换Word文件三、工具特性分析优点局

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

Java利用Spire.Doc for Java实现在模板的基础上创建Word文档

《Java利用Spire.DocforJava实现在模板的基础上创建Word文档》在日常开发中,我们经常需要根据特定数据动态生成Word文档,本文将深入探讨如何利用强大的Java库Spire.Do... 目录1. Spire.Doc for Java 库介绍与安装特点与优势Maven 依赖配置2. 通过替换

C#实现插入与删除Word文档目录的完整指南

《C#实现插入与删除Word文档目录的完整指南》在日常的办公自动化或文档处理场景中,Word文档的目录扮演着至关重要的角色,本文将深入探讨如何利用强大的第三方库Spire.Docfor.NET,在C#... 目录Spire.Doc for .NET 库:Word 文档处理利器自动化生成:C# 插入 Word

Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)

《Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)》在职场中,Word文档是公认的好伙伴,但你有没有被它折磨过?批量生成合同、制作报告以及发放证书/通知等等,这些重复、低效... 目录重复性文档制作,手动填充模板,效率低下还易错1.python-docx入门:Word文档的“瑞士

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

C++读写word文档(.docx)DuckX库的使用详解

《C++读写word文档(.docx)DuckX库的使用详解》DuckX是C++库,用于创建/编辑.docx文件,支持读取文档、添加段落/片段、编辑表格,解决中文乱码需更改编码方案,进阶功能含文本替换... 目录一、基本用法1. 读取文档3. 添加段落4. 添加片段3. 编辑表格二、进阶用法1. 文本替换2