为了账号安全,请及时绑定邮箱和手机立即绑定

如何修复CodingBat中的递归代码错误?

如何修复CodingBat中的递归代码错误?

守候你守候我 2023-08-04 16:40:40
所以,我正在 CodingBat 上解决这个问题给定一个字符串,递归(无循环)计算一个新字符串,其中所有出现的“pi”都已替换为“3.14”。更改Pi(“xpix”)→“x3.14x”更改Pi(“pipi”)→“3.143.14”ChangePi("pip") → "3.14p"这是我的代码:public String changePi(String str) {    if (str.length() < 2)        return str;    char c1 = str.charAt(0);    char c2 = str.charAt(1);    if (c1 == 'p' && c2 == 'i')        return "3.14" + changePi(str.substring(2));    return c1 + c2 + changePi(str.substring(2));}此代码不适用于许多测试用例,如下图所示我无法理解我的递归代码出了什么问题以及为什么它显示这样的输出。谁能帮助我理解我做错了什么?
查看完整描述

3 回答

?
SMILET

TA贡献1796条经验 获得超4个赞

您的解决方案需要一个小调整 - 当您找到 ap和i在一起时,您正确地向前跳过 2 个字符以查看字符串的其余部分 - 您正在使用return "3.14" + changePi(str.substring(2));.


但是,当您没有找到和p在一起i时,您需要更改逻辑以仅向前跳过一个字符而不是两个字符。所以代替这个:


return c1 + c2+ changePi(str.substring(2));

做这个:


return c1 + changePi(str.substring(1));

进行更改后,我得到以下输出(使用您的每个输入),该输出与您的预期输出相匹配:


x3.14x

3.143.14

3.14p

3.14

hip

p

x


3.14xx

xyzzy



查看完整回答
反对 回复 2023-08-04
?
沧海一幻觉

TA贡献1824条经验 获得超5个赞

这里有几个解决该问题的方法。第二种和你的方法类似。在第一个中,我最初包含了目标替换文本,因此我需要确定其长度。因此,"pi".length()我决定将其保留下来。



       public static void main(String[] args) {

          String[] tests = {

                "piabcpiefgpi", "xxxxxxpix", "xpix", "pip", "3.14", "3.14p",

                "hip", "p", "x", "", "pixx", "xyzzy"

          };

          for (String t : tests) {

             System.out.println(t + " --> " + replaceV2(t));

          }

       }


       public static String replaceV1(String a) {

          int i = a.indexOf("pi");

          if (i < 0) {

             return a;

          }

          return replaceV1(

                a.substring(0, i) + "3.14" + a.substring(i + "pi".length()));

       }


       public static String replaceV2(String a) {

          if (a.length() < 2) {

             return a;

          }


          if (a.startsWith("pi")) {

             a = "3.14" + replaceV2(a.substring(2));

          }

          return a.substring(0, 1) + replaceV2(a.substring(1));

       }

    }

他们都打印以下内容。


piabcpiefgpi --> 3.14abc3.14efg3.14

xxxxxxpix --> xxxxxx3.14x

xpix --> x3.14x

pip --> 3.14p

3.14 --> 3.14

3.14p --> 3.14p

hip --> hip

p --> p

x --> x

 --> 

pixx --> 3.14xx

xyzzy --> xyzzy


查看完整回答
反对 回复 2023-08-04
?
RISEBY

TA贡献1856条经验 获得超5个赞

'''  change pi to 3.14 python code'''


def changePi(s):

    if len(s) == 2 and s == 'pi' :  return '3.14'

    if len(s) <= 2 :  return s 

    chars , sub = s[0:2] , s[1:]

    if chars == 'pi':

       chars = '3.14'

       sub = sub[1:]

    else:  chars =  chars[0]

    return chars + changePi(sub) 


print changePi("xpix") 

print changePi("pipi") 

print changePi("pip")


查看完整回答
反对 回复 2023-08-04
  • 3 回答
  • 0 关注
  • 170 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信