题目描述:
给定一个由空格分割单词的句子 S
。每个单词只包含大写或小写字母。
我们要将句子转换为 “Goat Latin”(一种类似于 猪拉丁文 - Pig Latin 的虚构语言)。
山羊拉丁文的规则如下:
- 如果单词以元音开头(a, e, i, o, u),在单词后添加
"ma"
。
例如,单词"apple"
变为"applema"
。 - 如果单词以辅音字母开头(即非元音字母),移除第一个字符并将它放到末尾,之后再添加
"ma"
。
例如,单词"goat"
变为"oatgma"
。 - 根据单词在句子中的索引,在单词最后添加与索引相同数量的字母
'a'
,索引从1开始。
例如,在第一个单词后添加"a"
,在第二个单词后添加"aa"
,以此类推。
返回将 S
转换为山羊拉丁文后的句子。
示例 1:
输入: "I speak Goat Latin"
输出: "Imaa peaksmaaa oatGmaaaa atinLmaaaaa"
示例 2:
输入: "The quick brown fox jumped over the lazy dog"
输出: "heTmaa uickqmaaa rownbmaaaa oxfmaaaaa umpedjmaaaaaa overmaaaaaaa hetmaaaaaaaa azylmaaaaaaaaa ogdmaaaaaaaaaa"
说明:
S
中仅包含大小写字母和空格。单词间有且仅有一个空格。1 <= S.length <= 150
。
解题思路:
- 将给定字符串按照 空格拆分为多个字符串,存放在数组中。
- 将数组中每个字符串按照给定的规则转换成山羊拉丁文。
- 将数组中转换好的字符串全部拼接起来,每个字符串之间要加空格。
代码实现:
class Solution3 {
public String toGoatLatin(String S) {
//把字符串按照“ ”拆分为多个字符串
String[] arr = S.split(" ");
for (int i = 0; i < arr.length; i++) {
arr[i] = change(arr[i],i);
}
//把转换好的字符串拼接起来
StringBuffer stringBuffer = new StringBuffer(arr[0]);
for (int i = 1; i < arr.length-1; i++) {
stringBuffer.append(" ");
stringBuffer.append(arr[i]);
}
if (arr.length > 1) {
stringBuffer.append(" ");
stringBuffer.append(arr[arr.length-1]);
}
return stringBuffer.toString();
}
//把数组中第k单词转换成山羊拉丁文
public String change(String str,int index) {
int n = str.length();
StringBuffer stringBuffer = new StringBuffer(str);
char[] arr = new char[1];
stringBuffer.getChars(0,1,arr,0);
switch (arr[0] ) {
case 'a':
case 'A':
case 'e':
case 'E':
case 'i':
case 'I':
case 'o':
case 'O':
case 'u':
case 'U':
stringBuffer.append("ma");
break;
default:
stringBuffer = stringBuffer.delete(0,1);
stringBuffer.append(arr[0]);
stringBuffer.append("ma");
break;
}
index += 1;
int i = 0;
while (i < index) {
stringBuffer.append("a");
i++;
}
return stringBuffer.toString();
}
}