Python实现的旋转数组功能算法示例
作者:linfeng886 发布时间:2021-09-11 20:49:46
本文实例讲述了Python实现的旋转数组功能算法。分享给大家供大家参考,具体如下:
一、题目
给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数。
例1:
输入: [1,2,3,4,5,6,7] 和 k = 3
输出: [5,6,7,1,2,3,4]
解释:
向右旋转 1 步: [7,1,2,3,4,5,6]
向右旋转 2 步: [6,7,1,2,3,4,5]
向右旋转 3 步: [5,6,7,1,2,3,4]
例2:
输入: [-1,-100,3,99] 和 k = 2
输出: [3,99,-1,-100]
解释:
向右旋转 1 步: [99,-1,-100,3]
向右旋转 2 步: [3,99,-1,-100]
说明:
1.尽可能想出更多的解决方案,至少有三种不同的方法可以解决这个问题。
2.要求使用空间复杂度为 O(1) 的原地算法。
二、解法
解法一
以倒数第 k 个值为分界线,把 nums 截成两组再组合。因为 k 可能大于 nums 的长度(当这两者相等的时候,就相当于 nums 没有移动),所以我们取 k % len(nums)
,k 和 nums 的长度取余,就是最终我们需要移动的位置
代码如下:
if nums:
k = k % len(nums)
nums[:]=nums[-k:]+nums[:-k]
时间:64ms,击败了98%
附:本机测试示例代码:
# -*- coding:utf-8 -*-
nums= [1,2,3,4,5,6,7]
k =3
if nums:
k = k % len(nums)
nums[:]=nums[-k:]+nums[:-k]
print(nums)
运行结果:
[5, 6, 7, 1, 2, 3, 4]
解法二
先把 nums 最后一位移动到第一位,然后删除最后一位,循环k次。k = k % len(nums)
,取余
代码如下:
if nums:
k = k % len(nums)
while k > 0:
k -= 1
nums.insert(0, nums[-1])
nums.pop()
时间:172ms,击败了16%
附:本机测试示例代码:
# -*- coding:utf-8 -*-
nums= [1,2,3,4,5,6,7]
k =3
if nums:
k = k % len(nums)
while k > 0:
k -= 1
nums.insert(0, nums[-1])
nums.pop()
print(nums)
运行结果:
[5, 6, 7, 1, 2, 3, 4]
解法三
先把 nums 复制到 old_nums ,然后 nums 中索引为 x 的元素移动 k 个位置后,当前索引为 x+k,其值为 old_nums[x]
。,所以我们把 x+k 处理成 (x+k)%len(nums)
,取余操作,减少重复的次数。
代码如下:
if nums:
old_nums = nums[:]
l = len(nums)
for x in range(l):
nums[(x+k) % l] = old_nums[x]
时间:64ms,击败了98%
附:本机测试示例代码:
# -*- coding:utf-8 -*-
nums= [1,2,3,4,5,6,7]
k =3
if nums:
old_nums = nums[:]
l = len(nums)
for x in range(l):
nums[(x+k) % l] = old_nums[x]
print(nums)
运行结果:
[5, 6, 7, 1, 2, 3, 4]
希望本文所述对大家Python程序设计有所帮助。
来源:https://blog.csdn.net/linfeng886/article/details/81981192


猜你喜欢
- 我就废话不多说了,还是直接看代码吧!import numpyworld_alchol=numpy.genfromtxt("worl
- 笔者通过一周的时间,询问了许多设计人员真实用户,以便确保这六个方面确实是大多数用户所不喜并且有非常大的概率普遍存在于众多的医疗网站之中。那么
- 微博上讨论MySQL在删除大表engine=innodb(30G+)时,如何减少MySQL hang的时间,现做一下简单总结: 当buffe
- 这个是捕获键盘事件输入状态的js代码,它可以判断你敲打了键盘的那个键,ctrl、shift,26个字母等等,返回具体键盘值。Javascri
- 详解java调用ffmpeg转换视频格式为flv注意:下面的程序是在Linux下运行的,如果在windows下rmvb转换成avi会出现问题
- 这是毕业校招二面时遇到的手写编程题,当时刚刚开始学习python,整个栈写下来也是费了不少时间。毕竟语言只是工具,只要想清楚实现,使用任何语
- 网上有很多免费的ip地址,都是可以使用的,但是如果手动来获取太麻烦,这里通过Python自动抓取,可以批量获取。代码如下:# -*- cod
- 如何写入超长的字符串? 我们可使用Command写入,来完成大容量的字符串的操作: dim&n
- 1.数据和日志文件分开存放在不同磁盘上数据文件和日志文件的操作会产生大量的I/O。在可能的条件下,日志文件应该存放在一个与数据和索引所在的数
- 对于非连续数据集,数据可视化时候需要每七天一个采样点。要求是选择此前最新的数据作为当日的数据展示,譬如今天是2019-06-18,而数据集里
- 阅读上一篇:FrontPage XP设计教程2——网页的编辑 制作一个漂亮的网页,离不开网页整体布局的设计,网页布局设计的合理与否,直接影响
- 本文实例讲述了Python mutiprocessing多线程池pool操作。分享给大家供大家参考,具体如下:python — mutipr
- 从这节开始,将会给大家介绍几个ASP中的三大通用类,它贯穿于我所设计的三层架构中,是对ASP语法的扩展,可以提高很多细节处理上的效率,可以算
- 一、Python 下载Python是运行的环境,必不可少,如果你是Linux系统的话,不用安装,自带了Python。首先我们打开浏览器搜索P
- 我们知道**代表次方。如下>>>12 * 12144>>>12 ** 2144>>>a
- 附上官网地址:https://pytorch.org/docs/stable/index.html1.torch.squeezesqueez
- 柱状图分类QBarSeries:竖向柱状图QPercentBarSeries:竖向百分比柱状图QStackedBarSeries:竖向堆叠柱
- 不过,如果您需要查找文档中的一个特定的元素,最有效的方法是 getElementById()。 不过要注意的是使用getElementByI
- 一、什么是异常?异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行。一般情况下,在Python无法正常处理程序时就会发生一
- 本文实例分析了python开发之list操作。分享给大家供大家参考,具体如下:对python中list的操作,大家可以参考《Python l