我正在尝试使用递归方法计算字母“e”出现在给定字符串中的实例数。我的测试字符串是Count my e's please!
. 这是到目前为止的代码:
public static int showE(String s, int count, int index)
{
if (index == -1) return count;
String e = "e";
int i = s.indexOf(e, index);
if (i != -1) count ++;
return showE(s, count, i);
}
当我调试代码时,int i
将保持在 9 而不是通过每次调用增加。
我认为由于最后一行代码用作int i
输入,它会int index
通过每次调用测试字符串将方法的签名设置为 9、15 和 18。一旦不再检测到字母 e,我认为 int i
会将 -1 发送到签名,然后int count
返回到 main 方法。但是,调试表明,int i
每次调用都会将其设置为 9,从而导致 StackOverflowError。如何解决这个问题?
编辑:这是响应斯蒂芬 C 的代码。对格式感到抱歉:
public static int showE(int count, int index)
{
String e = "e";
index = s.indexOf(e, 0)
for(int i = index; i = < s.length() - 1; i++)
{
if (index == e) count++;
}
return count;
}