这是悦乐书的第364次更新,第392篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第226题(顺位题号是953)。在外语中,令人惊讶的是,他们也使用英文小写字母,但可能使用不同的顺序。字母表的顺序是小写字母的一些排列。

给定用外语编写的单词序列以及字母表的顺序,当且仅当给定单词在这种外来语言中按字典排序时才返回true。

例1:

输入:words = [“hello”,“leetcode”],order =“hlabcdefgijkmnopqrstuvwxyz”

输出:true

说明:由于'h'在此语言中位于'l'之前,因此序列已排序。

例2:

输入:words = [“word”,“world”,“row”],order =“worldabcefghijkmnpqstuvxyz”

输出:false

说明:由于'd'在此语言中位于'l'之后,然后是单词[0]>单词[1],因此序列未排序。

例3:

输入:words = [“apple”,“app”],order =“abcdefghijklmnopqrstuvwxyz”

输出:false

说明:前三个字符“app”匹配,第二个字符串更短(大小)。根据词典规则“apple”>“app”,因为'l'>'∅',其中'∅'定义为空白字符小于任何其他字符。

注意

  • 1 <= words.length <= 100

  • 1 <= words [i] .length <= 20

  • order.length == 26

  • words[i]order中的所有字符都是英文小写字母。

02 第一种解法

题目的意思是给定一个自定义的字母排列顺序,然后根据这个排列顺序来判断字符串数组中的字符串是不是顺序排列的,是就返回true,不是就返回false

正常的字母排列顺序肯定是abcde......xyz这样,但是题目给的不一定是这样,所以需要先将字母顺序建立起来,使用一个HashMap来存,记为dictkey为字母,value为字母所在的位置(在字符串order中的位置),接着开始处理words中的字符串。

我们依次比较相邻的两个字符串即可,对于前后两字符串的长度关系,有两种情况,两者长度相等或者一长一短,取两字符串长度中的较小值作为循环次数的上限,避免越界风险,并且后续还会用到这个较小的字符串长度。

获取两字符串当前字符在dict中的value值,并且做减法,如果两字符所在的位置之差为0,说明字符相,继续往下循环,指导不等于0。

如果两字符所在的位置之差为-1,说明顺序是对的,继续处理下一批相邻的字符串即可。

如果两字符所在的位置之差大于0,即前一个字符串中的当前字符在后一个字符串中的当前字符之后,即后一个字符串应该在前,返回false

如果两字符所在的位置之差等于0,即其中有个字符串短些,但是两字符串长度的较小值不等于前一个字符串的长度,即短的字符串在后,返回false,可以参见题目给的例子三。

public boolean isAlienSorted(String[] words, String order) {
Map<Character, Integer> dict = new HashMap<Character, Integer>();
for (int i=0; i<order.length(); i++) {
dict.put(order.charAt(i), i);
}
int n = words.length;
for (int i=0; i<n-1; i++) {
int res = 0;
String s = words[i], s2 = words[i+1];
int j = s.length(), k = s2.length();
int min = Math.min(j, k);
// 只有两边的字母相同,循环才会继续执行
for (int m=0; m < min && res == 0; m++) {
res = dict.get(s.charAt(m))-dict.get(s2.charAt(m));
}
if (res > 0 || (res == 0 && min != j)) {
return false;
}
}
return true;
}

03 第二种解法

针对上面的解法,我们可以将HashMap换成26的整型数组,将比较单个字母前后位置的方法独立了出来,其他思路都是一样的。

public boolean isAlienSorted2(String[] words, String order) {
int[] dict = new int[26];
for (int i=0; i<order.length(); i++) {
dict[order.charAt(i)-'a'] = i;
}
int n = words.length;
for (int i=0; i<n-1; i++) {
if (!compareTwoString(words[i], words[i+1], dict)) {
return false;
}
}
return true;
} public boolean compareTwoString(String s, String s2, int[] dict){
int i = s.length(), j = s2.length();
int min = Math.min(i, j);
int res = 0;
for (int k=0; k<min && res == 0; k++) {
res = dict[s.charAt(k)-'a'] - dict[s2.charAt(k)-'a'];
}
if (res > 0) {
return false;
}
return res == 0 ? min==i : true;
}

04 小结

算法专题目前已连续日更超过七个月,算法题文章232+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode.953-验证外语字典顺序(Verifying an Alien Dictionary)的更多相关文章

  1. 【Leetcode_easy】953. Verifying an Alien Dictionary

    problem 953. Verifying an Alien Dictionary solution: class Solution { public: bool isAlienSorted(vec ...

  2. Verifying an Alien Dictionary

    2019-11-24 22:11:30 953. Verifying an Alien Dictionary 问题描述: 问题求解: 这种问题有一种解法是建立新的排序和abc排序的映射,将这里的str ...

  3. LeetCode 953. Verifying an Alien Dictionary (验证外星语词典)

    题目标签:HashMap 题目给了我们一个 order 和 words array,让我们依照order 来判断 words array 是否排序. 利用hashmap 把order 存入 map, ...

  4. LeetCode 953. Verifying an Alien Dictionary

    原题链接在这里:https://leetcode.com/problems/verifying-an-alien-dictionary/ 题目: In an alien language, surpr ...

  5. 【leetcode】953. Verifying an Alien Dictionary

    题目如下: In an alien language, surprisingly they also use english lowercase letters, but possibly in a ...

  6. 【LeetCode】953. Verifying an Alien Dictionary 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...

  7. LeetCode 953 Verifying an Alien Dictionary 解题报告

    题目要求 In an alien language, surprisingly they also use english lowercase letters, but possibly in a d ...

  8. 953.Verifying an Alien Dictionary(Map)

    In an alien language, surprisingly they also use english lowercase letters, but possibly in a differ ...

  9. [Swift]LeetCode953. 验证外星语词典 | Verifying an Alien Dictionary

    In an alien language, surprisingly they also use english lowercase letters, but possibly in a differ ...

随机推荐

  1. nicstat命令安装与分析

    nicstat安装包下载与安装: wget https://downloads.sourceforge.net/project/nicstat/nicstat-1.95.tar.gz tar -zxv ...

  2. 前端form表单与css

    form表单(******) 能够获取用户输入(输入,选择,上传的文件) 并且将用户输入的内容全部发送给后端 参数 action 控制数据提交的地址 三种书写方式 1.不写 默认就是朝当前这个页面所在 ...

  3. Fiddler debug 拦截文件

    前言 前端每次本地调试的需要重新build文件,而且如果当前文件是在另外一个项目中使用,则还需要拷贝到另外一个项目下面.这个工作很耗时.如果使用替换包,可以节省很多时间,也便于开发. 解决方案 用Fi ...

  4. 2017 网易游戏互娱游戏研发4.21(offer)

    网易游戏互娱(offer) 去年这个时候就参加过网易游戏的实习生招聘,到今年总共收到了4次拒信.不过这次运气好,终于get了最想要的offer.去年实习生互娱笔试挂,秋招笔试挂,今年春招互娱投了连笔试 ...

  5. hiho #1062 : 最近公共祖先·一(树,最近祖先)

    #1062 : 最近公共祖先·一 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho最近发现了一个神奇的网站!虽然还不够像58同城那样神奇,但这个网站仍然让小Ho乐在 ...

  6. LOJ-6284-数列分块入门8

    链接: https://loj.ac/problem/6284 题意: 给出一个长为 的数列,以及 个操作,操作涉及区间询问等于一个数 的元素,并将这个区间的所有元素改为 . 思路: 维护一个分块是否 ...

  7. postman 测试api接口

    安装:https://www.getpostman.com/ 谷歌插件安装需要翻墙才能访问,那么直接去官网下载pc端 代码图片: 非常简单 post: 代码图片: 剪头地方,必选

  8. 程序代码运行结果是(abdcbdcb)

    public class Test { public static boolean show(char ch) { System.out.print(ch); return true; } publi ...

  9. Mysql : Maximum execution time of 30 seconds exceeded

    在向Mysql数据库中插入数据时,提示Maximum execution time of 30 seconds exceeded.......翻译:最大运行时间超过30秒. 最后在php.ini中找到 ...

  10. Java-Thread 线程

    一.进程与线程的概念 进程和线程都是一个CPU工作时间段的描述,只是关注点不同. 进程(Process): 资源(CPU,内存等,文件,网络等)分配的基本单位.系统中有很多进程,它们都会使用内存.为了 ...