每日一题——山羊拉丁文

简介: 每日一题——山羊拉丁文

824. 山羊拉丁文

题目描述:

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

请你将句子转换为 “山羊拉丁文(Goat Latin,返回将 sentence 转换为山羊拉丁文后的句子。

山羊拉丁文的规则如下:

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

例如,单词 “apple” 变为 “applema” 。

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

例如,单词 “goat” 变为 “oatgma” 。

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

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

示例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”

题解:

func toGoatLatin(sentence string) string {
  assistStr := "aeiouAEIOU"
  words := strings.Split(sentence, " ")
  ansSlice:=make([]string,len(words))
  // 遍历words,对应的i,同样也是变化后的word在ansSlice切片中的位置
  for i, word := range words {
    index := i + 1
    if strings.Contains(assistStr, string(word[0])) {
      word = addA(word+"ma", index)
      ansSlice[i] = word
      continue
    } else {
      word = addA(word[1:]+string(word[0])+"ma", index)
      ansSlice[i] = word
      continue
    }
  }
  return strings.Join(ansSlice," ")
}
// word后追加a,index是多少,追加几个“a”
func addA(word string, index int) string {
  for i := 0; i < index; i++ {
    word = word + "a"
  }
  return word
}

提交结果:

目录
打赏
0
0
0
0
44
分享
相关文章
|
11月前
|
老鼠和奶酪
老鼠和奶酪
64 0
【刷题日记】824. 山羊拉丁文
本次刷题日记的第 40 篇,力扣题为:【刷题日记】824. 山羊拉丁文 ,简单
草莓熊系列
草莓熊系列。
110 0
1312:【例3.4】昆虫繁殖
1312:【例3.4】昆虫繁殖
111 1
【刷题日记】875. 爱吃香蕉的珂珂
本次刷题日记的第 57 篇,力扣题为:875. 爱吃香蕉的珂珂,中等
187 0
【刷题日记】875. 爱吃香蕉的珂珂
每日算法系列【LeetCode 875】爱吃香蕉的珂珂
每日算法系列【LeetCode 875】爱吃香蕉的珂珂
118 0
日拱算法:什么是“煎饼排序”?
通过“煎饼翻转”来进行排序,叫“煎饼排序”,那什么是“煎饼翻转”呢?(禁止套娃🐶)
LeetCode每日一题(6)——山羊拉丁文
山羊拉丁文 1.题目 2.示例 3.思路 4.代码 5.复杂度分析
192 0

相关实验场景

更多