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

相关文章

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Java利用poi实现word表格转excel

《Java利用poi实现word表格转excel》这篇文章主要为大家详细介绍了Java如何利用poi实现word表格转excel,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、每行对象类需要针对不同的表格进行对应的创建。package org.example.wordToEx

Python如何在Word中生成多种不同类型的图表

《Python如何在Word中生成多种不同类型的图表》Word文档中插入图表不仅能直观呈现数据,还能提升文档的可读性和专业性,本文将介绍如何使用Python在Word文档中创建和自定义各种图表,需要的... 目录在Word中创建柱形图在Word中创建条形图在Word中创建折线图在Word中创建饼图在Word

Python批量调整Word文档中的字体、段落间距及格式

《Python批量调整Word文档中的字体、段落间距及格式》这篇文章主要为大家详细介绍了如何使用Python的docx库来批量处理Word文档,包括设置首行缩进、字体、字号、行间距、段落对齐方式等,需... 目录关键代码一级标题设置  正文设置完整代码运行结果最近关于批处理格式的问题我查了很多资料,但是都没

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

基于Java实现模板填充Word

《基于Java实现模板填充Word》这篇文章主要为大家详细介绍了如何用Java实现按产品经理提供的Word模板填充数据,并以word或pdf形式导出,有需要的小伙伴可以参考一下... Java实现按模板填充wor编程d本文讲解的需求是:我们需要把数据库中的某些数据按照 产品经理提供的 word模板,把数据