基本上我想递归地得到这个:

“我给这句话写了一句话,“

看起来像这样:

“也许我已经写过这样的句子”


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;
}`


除第一个单词的第一个字母以外的所有内容都可以大写。大写单词的第一个字母时,如何使代码排除第一个单词?这可能递归吗?

最佳答案

您可以使用递归实现:

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

10-07 12:27
查看更多