利用模拟解决“山羊拉丁文”问题

Posted &小小白&

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用模拟解决“山羊拉丁文”问题相关的知识,希望对你有一定的参考价值。

十九、山羊拉丁文

19.1、题设要求

  句子中的索引,在单词最后添加与索引相同数量的字母’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 中的所有单词由单个空格分隔

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/goat-latin

19.2、解题思路

  先将字符串中的单词提取出来,再将元音字母放入到新建的set中,然后将首字母提取并进行判断,如果首字母为元音字母,直接加ma;如果不是,先移动第一个字母到末尾,再加ma。最后再给单词加相应的a以及空格,输出即可。

19.3、算法

class Solution 
    public String toGoatLatin(String sentence) 
        //先将字符串中的单词提取出来
        String[] words = sentence.split(" ");
        //创建一个元音的Set
        char[] vowels = 'a','e','i','o','u','A','E','I','O','U';
        //然后我们将它们放到Set里面去
        boolean[] v = new boolean[128];
        for (char c : vowels) 
            v[c] = true;
        
        StringBuilder result = new StringBuilder();
        for (int i = 0; i < words.length; i++) 
            StringBuilder temp = new StringBuilder(words[i]);;
            //将首字母提取出来
            char h = words[i].charAt(0);
            //判断是否为元音字母,如果是,直接加ma;如果不是,先移动第一位字母到末尾,再加ma.
            if (!v[h])
                //先将首字母删除
                temp.deleteCharAt(0);
                //然后移到结尾
                temp.append(h);
            
            //给单词最后加一个ma
            temp.append("ma");
            //给单词最后加相对应的a
            for (int j = 0; j <= i; j++) 
                temp.append('a');
            
            result.append(temp.toString());
            //如果不是最后一个单词,那就需要在单词的后面加一个空格
            if (i != words.length - 1)
                result.append(" ");
            
        
        return result.toString();
    

参考视频:B站up主Ronan0

以上是关于利用模拟解决“山羊拉丁文”问题的主要内容,如果未能解决你的问题,请参考以下文章

leetcode 824. 山羊拉丁文

LeetCode 山羊拉丁文[模拟 字符串] HERODING的LeetCode之路

LeetCode 824. 山羊拉丁文 / 396. 旋转函数 / 587. 安装栅栏(不会,经典凸包问题,学)

LeetCode-824 划水记录3

824. Goat Latin山羊拉丁文

LeetCode 824. Goat Latin (山羊拉丁文)