马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
程式1def A(x):
a = []
while x != 6:
x += 1
a = list([x]) + a
print(a)
A(0)
程式2def get_digits(n):
result = []
while n >= 10:
result = list([n % 10]) + result
n = n // 10
if n >= 0:
result = list([n % 10]) + result
print(result)
get_digits(123456)
程式1的a = list([x]) + a和程式2的result = list([n % 10]) + result拼接顺序相同,为什么程式1的输出值为[6, 5, 4, 3, 2, 1],而程式2的输出值为[1, 2, 3, 4, 5, 6],相反了?
第一个def A(x):
a = []
while x != 6:
x += 1
a = list([x]) + a
print(a)
A(0)
列表添加顺序是 :最后添加的元素位置是0
最先添加的是最后的位置a=[]
>>> a=list([1])+a
>>> a=list([2])+a
>>> a
[2, 1]
>>>
所以第一个打印是第二个def get_digits(n):
result = []
while n >= 10:
result = list([n % 10]) + result
n = n // 10
if n >= 0:
result = list([n % 10]) + result
print(result)
get_digits(123456)
你给函数的值是123456
也就是而所以第二添加顺序是654321
所以排序就是123456
打印就是123456
|