gpt4 book ai didi

java - 使用递归来测试两个字符串是否相同但方向相反

转载 作者:行者123 更新时间:2023-12-01 21:14:56 24 4
gpt4 key购买 nike

对于我的作业,我必须使用递归来测试两个字符串是否相同但相反。

这是实际问题:

编写一个名为 isStringReversed 的递归方法,给定两个 String 参数,如果两个字符串包含相同的字符序列但顺序相反(忽略大写),则返回 true,否则返回 false。例如,isStringReversed("piano", "oNaIp") 将返回 true。注意:null(空)字符串和一个字母的字符串都是其自身的反转。

这是我所做的,但是当我执行该程序时,我总是得到错误返回。这是我的代码:

public static boolean isStringReversed(String s1, String s2) {
if (s1 == null || s2 == null || s1.length() == 1 || s2.length() == 1) {
return true;
}else if (s1.length() != s2.length()) {
return false;
}else {
char s1first = Character.toLowerCase(s1.charAt(0));
char s2last = Character.toLowerCase(s2.charAt(s2.length() - 1));

if (s1first == s2last){
String s1shorter = s1.substring(0, s1.length() - 1);
String s2shorter = s2.substring(0, s2.length() - 1);
return isStringReversed(s1shorter, s2shorter);
}else {
return false;
}
}
}

最佳答案

s1first 上执行 substring 时,您应该删除第一个字符,而不是最后一个。

仅在上面一行比较 s1first第一个字符和s2last最后字符。因此,一旦确定它们相等,就将其删除并继续递归。

关于java - 使用递归来测试两个字符串是否相同但方向相反,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40388569/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com