本文共 1334 字,大约阅读时间需要 4 分钟。
1 #题目:利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | 2 3 li = list ( input ( '请输入5个字符:' )) 4 n = len (li) 5 i = 0 6 7 def order(li,n,i): 8 if i < = n - 1 - i: 9 tmp = li[i] 10 li[i] = li[n - 1 - i] 11 li[n - 1 - i] = tmp 12 i + = 1 13 order(li,n,i) 14 return (li) 15 16 print (order(li,n,i)) |
运行结果:
1 2 3 4 5 6 7 | [root@HK code_100] # python code_27.py 请输入 5 个字符:abcdefghi123456768 [ '8' , '6' , '7' , '6' , '5' , '4' , '3' , '2' , '1' , 'i' , 'h' , 'g' , 'f' , 'e' , 'd' , 'c' , 'b' , 'a' ] [root@HK code_100] # python code_27.py 请输入 5 个字符:abcde [ 'e' , 'd' , 'c' , 'b' , 'a' ] [root@HK code_100] # |
代码解释:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | #思路:遍历经过输入转换后的列表li,通过三方参数赋值,将第一个和最后一个元素交换位置,然后递归新的列表, # 将新列表的第二个元素和倒数第二个元素交换位置,以此类推,全部交换完之后,列表就会做到反转 2 3 li = list ( input ( '请输入5个字符:' )) #接收输入的5个字符,并且转换成列表 4 n = len (li) #计算列表长度,以便后面使用 5 i = 0 #定义参数i为从0开始 6 7 def order(li,n,i): #定义函数order,传入三个参数,li列表,列表长度,列表下标 8 if i < = n - 1 - i: #条件判断列表正数元素小于或者等于列表倒数元素,防止重复交换位置,因为是小于或者等于, 所有列表个数是单数还是双数都不受影响 9 tmp = li[i] #从这往后三条是通过三方参数tmp交换两个数值 10 li[i] = li[n - 1 - i] 11 li[n - 1 - i] = tmp 12 i + = 1 #正数元素下标依次累加 13 order(li,n,i) #将之前交换完元素的的列表递归到这个函数,传入新的参数,继续计算,一直到所有元素都有交换 14 return (li) #全部交换完之后返回新的列表 15 16 print (order(li,n,i)) #打印结果 |