我坚持的那个(digitsSorted,数字5)如下:你调用一个函数传递一个数字作为参数。如果该数字中的数字按递增顺序排序,则该函数返回True,否则返回False。允许重复的数字。该函数也应该能够处理负数。根据定义对单个数字进行排序。
因此func(0),func(112234)或func(-345669)返回True,但func(4321)返回False,依此类推。
为了强制你使用递归,有一系列约束:没有循环,没有全局变量,没有日期结构,但是你想要的变量也很多,你也不能使用字符串来解决它。
我的代码是:
def digitsSorted(x):
if x < 0:
x = x * (-1)
digitsSorted(x)
elif (x/10) < 1:
return True
else:
remainder1 = x % 10
x = (x - remainder1) / 10
remainder2 = x % 10
if remainder1 >= remainder2:
digitsSorted(x)
else:
return False
当我调用函数时,我只在参数为单个数字时得到正确答案,否则返回None。但是我认为代码是正确的,因为当我改变:
return True
对于:
print(True)
return
与“返回False”行相同,代码可以正常工作。我无法解决问题所在。
提前致谢