python关于回文的一个小问题

发布网友 发布时间: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...

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com