有这样一个列表[1, 2, 3, 4, 5, 6, 7, 8, 9]编程实现该列表逆序排列,将其变为[9, 8, 7, 6, 5, 4, 3, 2, 1] 。 题目有了,看看怎么答,逆序排列,只需要将第一个和倒数第一个,第二个和倒数第二个,一直到中间那个位置的数字依次进行交换即可。
假设列表为data, 列表长度为len(data)
[1, 2, 3, 4, 5, 6, 7, 8, 9]
0 1 2 3 4 5 6 7 8
从上图的列表和其下标可得出如下结论:
列表第1个元素下标为0 最后一个元素为len(data) - 0
列表第2个元素下标为1 最后一个元素为len(data) - 1
列表第3个元素下标为2 最后一个元素为len(data) - 2
则我们遍历列表的时候假设循环变量为i, 上面的规律可表示为len(data) - 1 - i
现在开始写代码实现:
1
2
3
4
5
6
7
8
def inverse(data=None):
if not data or not isinstance(data, list) or len(data) < 1:
return
n = len(data)
for i, v in enumerate(data[0:int(n/2)]):
if v < data[n-1-i]:
data, data[n-1-i] = data[n-1-i], data # 交换元素
return data
单元测试
测试很重要,尤其是实现复杂功能的代码,为了避免每次改动都在代码中插一堆print,最好写测试代码,一次投入,回报长远。哈哈!
1
2
3
4
5
6
7
8
import unittest
class TestInverseMethods(unittest.TestCase):
def test_inverse(self):
data = [1, 2, 3, 4, 5, 6]
result = [6, 5, 4, 3, 2, 1]
self.assertEqual(inverse(data), result)
if __name__ == '__main__':
unittest.main()
.
----------------------------------------------------------------------
Ran 1 test in 0.002s
OK
看到如上输出,则表示测试通过
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com