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

相关文章

C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式

《C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式》Markdown凭借简洁的语法、优良的可读性,以及对版本控制系统的高度兼容性,逐渐成为最受欢迎的文档格式... 目录为什么要将文档转换为 Markdown 格式使用工具将 Word 文档转换为 Markdown(.

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

Python实现一键PDF转Word(附完整代码及详细步骤)

《Python实现一键PDF转Word(附完整代码及详细步骤)》pdf2docx是一个基于Python的第三方库,专门用于将PDF文件转换为可编辑的Word文档,下面我们就来看看如何通过pdf2doc... 目录引言:为什么需要PDF转Word一、pdf2docx介绍1. pdf2docx 是什么2. by

如何Python使用设置word的页边距

《如何Python使用设置word的页边距》在编写或处理Word文档的过程中,页边距是一个不可忽视的排版要素,本文将介绍如何使用Python设置Word文档中各个节的页边距,需要的可以参考下... 目录操作步骤代码示例页边距单位说明应用场景与高级用China编程途小结在编写或处理Word文档的过程中,页边距是一个

Python使用python-docx实现自动化处理Word文档

《Python使用python-docx实现自动化处理Word文档》这篇文章主要为大家展示了Python如何通过代码实现段落样式复制,HTML表格转Word表格以及动态生成可定制化模板的功能,感兴趣的... 目录一、引言二、核心功能模块解析1. 段落样式与图片复制2. html表格转Word表格3. 模板生

Java如何根据word模板导出数据

《Java如何根据word模板导出数据》这篇文章主要为大家详细介绍了Java如何实现根据word模板导出数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... pom.XML文件导入依赖 <dependency> <groupId>cn.afterturn</groupId>

Java遍历HashMap的6种常见方式

《Java遍历HashMap的6种常见方式》这篇文章主要给大家介绍了关于Java遍历HashMap的6种常见方式,方法包括使用keySet()、entrySet()、forEach()、迭代器以及分别... 目录1,使用 keySet() 遍历键,再通过键获取值2,使用 entrySet() 遍历键值对3,

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

JAVA保证HashMap线程安全的几种方式

《JAVA保证HashMap线程安全的几种方式》HashMap是线程不安全的,这意味着如果多个线程并发地访问和修改同一个HashMap实例,可能会导致数据不一致和其他线程安全问题,本文主要介绍了JAV... 目录1. 使用 Collections.synchronizedMap2. 使用 Concurren

Python实现word文档内容智能提取以及合成

《Python实现word文档内容智能提取以及合成》这篇文章主要为大家详细介绍了如何使用Python实现从10个左右的docx文档中抽取内容,再调整语言风格后生成新的文档,感兴趣的小伙伴可以了解一下... 目录核心思路技术路径实现步骤阶段一:准备工作阶段二:内容提取 (python 脚本)阶段三:语言风格调