发布网友 发布时间:2022-04-23 15:48
共2个回答
热心网友 时间:2022-05-07 01:31
第一个问题
s[1:-1]是返回出去s第一个和最后一个的字符串
比如s = "1234567"
则s[1:-1] 就是 “2345678”
第二个问题
ispalndrome("abc")时, s[0]='a' , s[-1]="c"
所以 s[0]==s[-1] 的结果是False,
所以 s[0]==s[-1] and ispalindrome(s[1:-1]) 的结果是 False and ispalindrome(s[1:-1])
所以return False
热心网友 时间:2022-05-07 02:49
假如是ABCBA 将string 视作是一个list,如果string是单字符,判定它为回文不用说;
看代码的运行调用,这其实是一个递归:
传入参数s为ABCBA ,s[0]=s[-1]的,and前面为True
继续调用ispalindrome,关键来了,它将去掉头去掉尾的string传给该方法继续判断(第二次调用的传递参数为BCB了,这就是为什么采用s[1:-1],其实是去掉已经判断过的头和尾),返回真
继续,再次调用ispalindrome()方法,此时头尾还是相等(B=B),故继续调用ispalindrome()判断“B”,而B是单字母,故最终返回了真值。
偶数长度的string是类似的,如果是回文是一直True and True and True...