LeetCode.953-验证外语字典顺序(Verifying an Alien Dictionary)

这是悦乐书的第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+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容

  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 4,380评论 0 5
  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,226评论 0 4
  • Lua 5.1 参考手册 by Roberto Ierusalimschy, Luiz Henrique de F...
    苏黎九歌阅读 13,780评论 0 38
  • 手动不易,转发请注明出处 --Trance 数据库系统命令: (1).查看存储过程状态:show pro...
    Trance_b54c阅读 1,659评论 0 8
  • 好久没写感恩日记了,虽然每天都有发生值得感激的的事情,但就是不想动,我接纳自己,不想动就不动。等待那个激起我动...
    罗秀春阅读 292评论 0 2