我是靠谱客的博主 笨笨摩托,最近开发中收集的这篇文章主要介绍【题目34】数组的循环右移,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

题目】有一个整数数组,现要求实现这个整数数组的循环右移。如:1,2,3,4,5

循环右移两位后的结果是,4,5,1,2,3

 

解析:

方法1: 假如要右移k位,可以每次右移1位,移动K次。每次移动的时候,将数组最后一个

数保存到一个局部变量中,其余的数向后移动一位,移动完成后,将临时变量中的数拷贝

到数组第一个数的位置。时间复杂度o(n^2),空间复杂度o(1)

方法2:将整个数组逆转,如果要移动K位,将前K个数再逆转,最后N-K个数也逆转一下

就得到了我们需要的结果。时间复杂度o(n), 空间复杂度o(1)

方法3:如果可以使用库函数的话,我们可以直接用memcpy,memmove来实现,时间复杂

度是o(n),空间复杂度是o(k),假设移动K位。

 

最后

以上就是笨笨摩托为你收集整理的【题目34】数组的循环右移的全部内容,希望文章能够帮你解决【题目34】数组的循环右移所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(34)

评论列表共有 0 条评论

立即
投稿
返回
顶部