【LeetCode---算法刷题】山羊拉丁文(题号: 824)

1. 问题描述

给你一个由若干单词组成的句子 sentence ,单词间由空格分隔。每个单词仅由大写和小写英文字母组成。
请你将句子转换为 “山羊拉丁文(Goat Latin)”(一种类似于 猪拉丁文 - Pig Latin 的虚构语言)。山羊拉丁文的规则如下:
如果单词以元音开头(‘a’, ‘e’, ‘i’, ‘o’, ‘u’),在单词后添加"ma"。
例如,单词 “apple” 变为 “applema” 。
如果单词以辅音字母开头(即,非元音字母),移除第一个字符并将它放到末尾,之后再添加"ma"。

例如,单词 “goat” 变为 “oatgma” 。
根据单词在句子中的索引,在单词最后添加与索引相同数量的字母’a’,索引从 1 开始。
例如,在第一个单词后添加 “a” ,在第二个单词后添加 “aa” ,以此类推。
返回将 sentence 转换为山羊拉丁文后的句子。

2. 解题思路

考察数组和字符串方法的运用
先把字符串转换成数组,判断每个数组元素的首字母进而做相应的处理。

3. 解题

/**
 * @param {string} sentence
 * @return {string}
 */
var toGoatLatin = function(sentence) {
    
    
  let sentenceArr = sentence.split(' ');
  let formatterArr =  sentenceArr.map((item, index) => {
    
    
    let firstLetter = item.slice(0, 1);
    if(firstLetter === 'a' || firstLetter === 'A' || firstLetter === 'e'
    || firstLetter === 'E' || firstLetter === 'i' || firstLetter === 'I'
    || firstLetter === 'o' || firstLetter === 'O' || firstLetter === 'u'
    || firstLetter === 'U') {
    
    
      item = item + 'ma' + 'a'.repeat(index + 1);
    } else {
    
    
      item = item.slice(1) + firstLetter + 'ma' + 'a'.repeat(index + 1);
    }
      return item;
    })
  return formatterArr.join(' ');
};

(1) 输出:
在这里插入图片描述
在这里插入图片描述

问题来源:力扣(LeetCode)
链接: https://leetcode-cn.com/problems/goat-latin/submissions/

猜你喜欢

转载自blog.csdn.net/honeymoon_/article/details/124255495
今日推荐