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)) #打印结果
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。