LeetCode 題庫 全 JAVA 解題
824. 山羊拉丁文
原題回顧:
給定一個由空格分割單詞的句子 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。
思路
變量解釋
vowel : hashset類型 的 元音字符組
t :當前第t個單詞
ans :返回的字符句子
word :當前掃描的單詞
first :當前單詞首字母
解題流程:
只觀解決問題,將原句按照空格進行分詞
判斷首字母是否為元音,
元音直接加入ans
非元音首字母移到末尾
單詞后統一加‘ma’
根據單詞索引,加t個字母‘a’
單詞后加空格字符
去掉最后一個空格字符
class Solution {
public String toGoatLatin(String S) {
Set vowel = new HashSet();
for (char c: new char[]{'a', 'e', 'i', 'o', 'u', 'A', 'E', 'I', 'O', 'U'})
vowel.add(c);
int t = 1;
StringBuilder ans = new StringBuilder();
for (String word: S.split(" ")) {
char first = word.charAt(0);
if (vowel.contains(first)) {
ans.append(word);
} else {
ans.append(word.substring(1));
ans.append(word.substring(0, 1));
}
ans.append("ma");
for (int i = 0; i < t; i++)
ans.append("a");
t++;
ans.append(" ");
}
ans.deleteCharAt(ans.length() - 1);
return ans.toString();
}
}
效果