基本上我想递归地得到这个:
“我给这句话写了一句话,“
看起来像这样:
“也许我已经写过这样的句子”
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);
}