力扣每日一题0421-824. 山羊拉丁文

142 阅读2分钟

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

给你一个由若干单词组成的句子 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"

找到每一个单词 + 模拟

我们可以对给定的字符串 sentence\textit{sentence} 进行一次遍历,找出其中的每一个单词,并根据题目的要求进行操作。

在寻找单词时,我们可以使用语言自带的 split()\texttt{split()} 函数,将空格作为分割字符,得到所有的单词。为了节省空间,我们也可以直接进行遍历:每当我们遍历到一个空格或者到达 sentence\textit{sentence} 的末尾时,我们就找到了一个单词。

当我们得到一个单词 ww 后,我们首先需要判断 ww 的首字母是否为元音字母。我们可以使用一个哈希集合 vowels\textit{vowels} 存储所有的元音字母 aeiouAEIOU\text{aeiouAEIOU},这样只需要判断 ww 的首字母是否在 vowels\textit{vowels} 中。如果是元音字母,那么单词本身保持不变;如果是辅音字母,那么需要首字母移到末尾,这里使用语言自带的字符串切片函数即可。在这之后,我们需要在末尾添加 m\text{m} 以及若干个 a\text{a},因此可以使用一个变量 cnt\textit{cnt} 记录需要添加的 a\text{a} 的个数,它的初始值为 11,每当我们得到一个单词,就将它的值增加 11

var toGoatLatin = function (sentence) {
  const vowels = new Set();
  vowels.add('a');
  vowels.add('e');
  vowels.add('i');
  vowels.add('o');
  vowels.add('u');
  vowels.add('A');
  vowels.add('E');
  vowels.add('I');
  vowels.add('O');
  vowels.add('U');
  let arr = sentence.split(" ")
  for (let i = 0; i < arr.length; i++) {
    let a = arr[i];
    if (vowels.has(a[0])) {
      a += "ma"
    } else {
      a += a.substring(0, 1)
      a = a.slice(1)
      a += "ma"
    }
    for (let j = 0; j < i + 1; j++) {
      a += "a"
    }
    arr[i] = a
  }
	return arr.join(" ")
};