题目
824.山羊拉丁文
题目大意
给你一个由若干单词组成的句子 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
中的所有单词由单个空格分隔
思路
题意很简单,就是对第 i i i个单词末端加入字符串:( i ∈ [ 1 , n ] i\in [1,n] i∈[1,n])
- 如果开头是元音,就直接加入
"ma"
,并且末尾加入 i i i个'a'
- 否则,将开头字符移到末尾,加入
"ma"
,并且末尾加入 i i i个'a'
使用C++
我感觉分割有点麻烦,于是我直接上python
,ls
存储每个单词,now
表示当前是第now
个单词,如果l[0]
是元音,直接l+'ma'+'a'*now
,否则l[1:]+l[0]+'ma'+'a'*now
,然后将其加入到ans
数组中,最后返回答案即可。不得不说,python
在针对字符串类型的题目的时候的确比C++
方便很多。
class Solution:
def toGoatLatin(self, sentence: str) -> str:
ls=sentence.split()
ans=[]
now=1
for l in ls:
a=""
if(l[0].lower() in ['a', 'e', 'i', 'o', 'u']):
a=l+'ma'+'a'*now
else:
a=l[1:]+l[0]+'ma'+'a'*now
now+=1
ans.append(a)
return ' '.join(ans)