力扣题解:824. 山羊拉丁文

94 阅读1分钟

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第30天,点击查看活动详情

1.描述

824. 山羊拉丁文 - 力扣(LeetCode)

给你一个由若干单词组成的句子 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 中的所有单词由单个空格分隔

2.分析

  1. 分离sentence中每个单词为数组arr项;
  2. 定义一个新数组为空用于接收处理后的每项单词; 3.定义元音字母数组;
  3. 初始化需要添加的m=“ma”,由题可知第一个单词需要添加的是“maa”
  4. 遍历数组arr,每项判断是否是元音字母,并进行对应处理后push到newArr中;判断结束m加"a";
  5. 返回新数组newArr拼接的字符串即可。

3.AC代码

/**
 * @param {string} sentence
 * @return {string}
 */
var toGoatLatin = function(sentence) {
    let arr=sentence.split(' ')
    let newArr=[];
    let note = ["a","e","i","o","u"]
    let m = "maa"
    arr.forEach((item)=>{
        if(note.includes(item.slice(0,1).toLowerCase())){
            newArr.push(item + m)
        }else{
            newArr.push(item.slice(1)+item.slice(0,1)+m)
        }
        m = m + "a"
    })

    return newArr.join(" ");
};

4.参考

方法一:使用字符串输入流istringstream;方法二:遍历得到字符串 - 山羊拉丁文 - 力扣(LeetCode)