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))
#打印结果
|
本文转自snc_snc 51CTO博客,原文链接:http://blog.51cto.com/netsyscode/1748838
,如需转载请自行联系原作者