leetcode刷题记录-824. 山羊拉丁文

130 阅读2分钟

一起养成写作习惯!这是我参与「掘金日新计划 · 4 月更文挑战」的第17天,点击查看活动详情

前言

今天的题目为简单,简单的模拟题,根据题目的要求进行分条件处理,没什么难度

每日一题

今天的题目是 824. 山羊拉丁文,难度为简单

  • 给你一个由若干单词组成的句子 sentence ,单词间由空格分隔。每个单词仅由大写和小写英文字母组成。

  • 请你将句子转换为 “山羊拉丁文(Goat Latin)”(一种类似于 猪拉丁文 - Pig Latin 的虚构语言)。山羊拉丁文的规则如下:

  • 如果单词以元音开头('a', 'e', 'i', 'o', 'u'),在单词后添加"ma"。

  • 例如,单词 "apple" 变为 "applema" 。

  • 如果单词以辅音字母开头(即,非元音字母),移除第一个字符并将它放到末尾,之后再添加"ma"。

  • 例如,单词 "goat" 变为 "oatgma" 。

  • 根据单词在句子中的索引,在单词最后添加与索引相同数量的字母'a',索引从 1 开始。

  • 例如,在第一个单词后添加 "a" ,在第二个单词后添加 "aa" ,以此类推。

  • 返回将 sentence 转换为山羊拉丁文后的句子。

 

示例 1:

输入:sentence = "I speak Goat Latin"
输出:"Imaa peaksmaaa oatGmaaaa atinLmaaaaa"

示例 2:

输入:sentence = "The quick brown fox jumped over the lazy dog"
输出:"heTmaa uickqmaaa rownbmaaaa oxfmaaaaa umpedjmaaaaaa overmaaaaaaa hetmaaaaaaaa azylmaaaaaaaaa ogdmaaaaaaaaaa"

 

提示:

  • 1 <= sentence.length <= 150
  • sentence 由英文字母和空格组成
  • sentence 不含前导或尾随空格
  • sentence 中的所有单词由单个空格分隔

题解

简单模拟

题目比较简单,根据要求模拟每一个单词会出现的变化即可,我们可以维护一个数组存放题目说所的元音字母,碰到的每一个单词就去判断第一个是否是元音,以此来判断进行哪一种操作。并且通过字符串分割,能拿到每一个单词组成的数组,也能够根据在数组中的位置来添加尾部的 a

  1. 新建一个数组 chArr 存放大小写的元音字母

  2. 将句子根据空格分割,得到单词组成的数组

  3. 循环单词数组,每次都去判断第一个字母是否在 chArr 中

  4. 在就在单词尾部加上ma和对应数量的a

  5. 不在就移出第一个字母,并且放到尾部,然后再加上ma和对应数量的a

  6. 用一个数组来保留每一次循环的结果

  7. 最后返回数组用空格凭借的句子。

/**
 * @param {string} sentence
 * @return {string}
 */
 var toGoatLatin = function(sentence) {
    const chArr = ['a', 'e', 'i', 'o', 'u', 'A', 'E', 'I', 'O', 'U'];
    const items = sentence.split(' ');
    const res = [];
    let temp = 'a';
    for(let item of items){
        if(chArr.includes(item[0])){
            item += 'ma' + temp;
        }else{
            item = item.substr(1) + item[0] + 'ma' + temp;
        }
        temp += 'a';
        res.push(item);
    }
    return res.join(' ');
};

image.png