调用该函数,检查范围内的回文

时间:2013-07-01 20:18:08

标签: python python-2.7

我正在尝试创建一个函数,它以递归方式检查给定范围内的回文。该范围被发送到“is_palindrome_multi”,然后调用“is_palindrome”。 但是,它不适用于高于10的数字,因此限制步骤似乎是:

  

elif data [0] == data [-1]:

语句。为什么它不会像11,22这样的数字返回?我将很感激解释。

def is_palindorme_multi(beg, end):
    for i in range(beg, end):
        i = str(i)
        if is_palindrome(i) == True:
            print "Palindrome"
        else:
            print "Not palindrome"


def is_palindrome(data):    
    print data,
    if len(data)==1 or len(data)==0:
        return True
    elif data[0]==data[-1]:
        is_palindrome(data[1:-1])
    else:
        return False

1 个答案:

答案 0 :(得分:6)

您没有返回递归调用的结果。

更改您的elif

elif data[0]==data[-1]:
    is_palindrome(data[1:-1])

为:

elif data[0]==data[-1]:
    return is_palindrome(data[1:-1])

但是,我只需将您的is_palindrome方法更改为:

def is_palindrome(data): 
    return data == data[::-1]

真的,这里不需要使用递归。