我希望学习在Java中如何处理字符串。目前我想要输入一个字符串并替换掉其中的任何字符。
以下是我当前的低效(而且我认为有点儿傻)函数。这个函数只是为了能够工作而被编写出来的。
public String convertWord(String word)
{
return word.toLowerCase().replace('á', 'a')
.replace('é', 'e')
.replace('í', 'i')
.replace('ú', 'u')
.replace('ý', 'y')
.replace('ð', 'd')
.replace('ó', 'o')
.replace('ö', 'o')
.replaceAll("[-]", "")
.replaceAll("[.]", "")
.replaceAll("[/]", "")
.replaceAll("[æ]", "ae")
.replaceAll("[þ]", "th");
}
我运行了100万次,并花费8182毫秒的时间。那么,我应该如何改变这个函数,使其更加高效?
找到解决方案:
将函数转换为以下形式
public String convertWord(String word)
{
StringBuilder sb = new StringBuilder();
char[] charArr = word.toLowerCase().toCharArray();
for(int i = 0; i < charArr.length; i++)
{
// Single character case
if(charArr[i] == 'á')
{
sb.append('a');
}
// Char to two characters
else if(charArr[i] == 'þ')
{
sb.append("th");
}
// Remove
else if(charArr[i] == '-')
{
}
// Base case
else
{
sb.append(word.charAt(i));
}
}
return sb.toString();
}
执行这个函数100万次需要518毫秒,所以我认为它已经足够高效了。感谢大家的帮助 :)