Skip to content

Latest commit

 

History

History
61 lines (47 loc) · 1.81 KB

README.md

File metadata and controls

61 lines (47 loc) · 1.81 KB

山羊拉丁文

难度:简单

https://leetcode-cn.com/problems/goat-latin/

题目

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

解题

/**
 * 模拟
 * 时间复杂度 O(N)  空间复杂度 O(N)
 * @param sentence
 * @returns
 */
export function toGoatLatin(sentence: string): string {
  const arr = sentence.split(' ')
  const vowel = ['a', 'e', 'i', 'o', 'u']
  let suffix = 'maa'
  for (let i = 0; i < arr.length; i++) {
    const word = arr[i]
    arr[i] = vowel.includes(word[0].toLowerCase())
      ? word + suffix
      : word.substring(1) + word.substring(0, 1) + suffix
    suffix += 'a'
  }

  return arr.join(' ')
}