力扣: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。

思路:

其实没有什么思路。。。用两个变量当指针,其中一个right从最左边开始扫描当遇到空格就停下来,另一个left留在最左边(一个单词的最左边),当right遇到空格停下来,left和right之间刚好是一个单词,这是对单词进行判断和修改之类的,完了时候,left移到rigth(也就是空格)的后一个,指向下一个单词的第一个字母,right移到left的位置继续往后扫描遇到空格停下来这样循环。

class Solution {
    public String toGoatLatin(String S) {
         S += " ";
         char[] c = S.toCharArray();
        String s1 = S;
        String s = "";
        int left = 0;
        int right = 0;
        int index = 1;
        while (right < c.length && left < c.length) {
            if (c[right] == ' '|| right == c.length-1) {
                if (c[left] == 'A' || c[left] == 'E' || c[left] == 'I' || c[left] == 'O' || c[left] == 'U' || c[left] == 'a' || c[left] == 'e' || c[left] == 'i' || c[left] == 'o' || c[left] == 'u') {
                    s += s1.substring(left, right) + "ma";
                    left = right + 1;
                } else {
                    s += s1.substring(left + 1, right) + S.charAt(left) + "ma";
                    left = right+1;
                }
                for (int i = 0; i < index; i++) {
                    s += "a";
                }
                index++;
                if(right!=c.length-1){
                    s += " ";
                }
                right = left;
            } else right++;
        }
        return s;
    }
}

你可能感兴趣的:(java)