1 #题目:利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。
代码:
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))
运行结果:
[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]#
代码解释:
#思路:遍历经过输入转换后的列表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)) #打印结果