将给定的字符串递归转换为驼峰式大小写

时间:2019-02-12 17:43:00

标签: java recursion

基本上,我想递归地得到它:

“我有一个句子,喜欢这样的句子”

外观如下:

“也许我已经写了这样的帖子”

  • n>每个单词之前,之间和之后的0个空格
  • 各种大写和小写字母 例如:“喜欢”

我认为我的理解:

  • 使用string.charAt(i)将特定字符与空格进行比较
  • 使用Character.isUpperCase()进行案例检查

我不明白的地方:

  • 由于字符串是不可变的,递归将如何更改字符串

  • 基本情况将是什么

  • 如何仅大写每个单词的第一个字母在第一个单词之后

编辑: 这是我在一些有用的提示之后提出的: `公共静态字符串toCamelCase(String str){

    if(str.length() == 1) {
        if(str.charAt(0) == ' ') {
            return "";
        } else {
            return str;
        }
    } else if(str.charAt(0) == ' ' && str.length() != 1) {
        if(str.charAt(1) != ' ') {
            return str.substring(1, 2).toUpperCase() + toCamelCase(str.substring(2, str.length()));
        } else {
            return toCamelCase(str.substring(1, str.length()));
        }
    } else if(str.charAt(0) != ' ' && str.length() != 1) {
        if(str.charAt(1) != ' ') {
            return str.substring(0,2).toLowerCase() + toCamelCase(str.substring(2, str.length()));
        } else {
            return str.substring(0,1).toLowerCase() + toCamelCase(str.substring(1, str.length()));
        }
    }
    return str;
}`

除第一个单词的第一个字母外,所有作品均大写。大写单词的第一个字母时,如何使代码排除第一个单词?可以递归吗?

1 个答案:

答案 0 :(得分:0)

您可以使用递归实现:

public String camelCase(String inputStr) {
   String s = inputStr.toLowerCase();
   String[] arr = s.split(" "); 
   s = arr[0];
   return getCamelCased(s,1,arr);
}

private String getCamelCased(String s, int index, String[] arr) {
   if(index >= arr.length)
        return s;

   String curr = arr[index++];
   s += curr.length()==1?curr.toUpperCase(): 
   (curr.toUpperCase.charAt(0)+curr.substring(1,curr.length()));

   return getCamelCased(s,index,arr);
}