008_Python列表练习_案例_旋转数组

给定一个数组,将数组中的元素向右移动 k 个位置,k 是非负数
示例:
输入:[1, 2, 3, 4, 5, 6, 7],k = 3
输出:[5, 6, 7, 1, 2, 3, 4]

# 分析:即将后 k 个放置在nums的最前面
nums = [1, 2, 3, 4, 5, 6, 7]
k = 3
# 从左边开始数,将剩余的len(nums)-k 个放在最后面(nums[:len(nums)-k]),另一半补在前面
# 相当别扭...
print(nums[len(nums)-k:] + nums[:len(nums)-k])

# 从右侧开始数,后 k 个放在最前面(nums[-k:]),另一半补在后面
print(nums[-k:] + nums[:-k])

执行结果:
在这里插入图片描述

发布了37 篇原创文章 · 获赞 0 · 访问量 5332

猜你喜欢

转载自blog.csdn.net/qq_21156327/article/details/103420604