山羊拉丁文-LeetCode(Java实现)

题目描述:

给定一个由空格分割单词的句子 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

解题思路:

  1. 将给定字符串按照 空格拆分为多个字符串,存放在数组中。
  2. 将数组中每个字符串按照给定的规则转换成山羊拉丁文。
  3. 将数组中转换好的字符串全部拼接起来,每个字符串之间要加空格。

代码实现:

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();
    }
}

猜你喜欢

转载自blog.csdn.net/weixin_43573824/article/details/88697978
今日推荐