数据结构:组旋转

本文首发为CSDN博客,地址:http://blog.csdn.net/xxzhangx/article/details/53464395

欢迎关注,谢谢!引用转载请注明地址和作者

题目:返回将一维数组向右旋转k个位置的结果。比如,一维数组{1,2,3,4,5},当k=2时,返回结果是{4,5,1,2,3}。要求常数级空间复杂度,允许修改原有数组。

伪代码

int [] rotataK(int [] A,int k)
{
    if (A == null || k >= A.length) return A;
    reverse(A,0,A.length-1);//反转整个数组
    reverse(A,0,k-1);//反转前k个数
    reverse(A,k,A.length-1);//反转剩下的数
    return A;
}

//辅助函数,反转从start到end的数
void reverse (int [] A,int start,int end)
{
    while (start < end)
    {
        //交换A[start]和A[end]两个数
        int temp = A[start]
        A[start] = A[end]
        start++;
        end--;
    }
}

R语言

R语言实现这个功能上,采用两种方式:

  • R语言自带的rev函数

  • 自己写的翻转函数

R语言带的rev函数

rotateK <- function(a,k)
{
  if (is.null(a) || length(a) <= k)
    return(a)
  a <- rev(a)
  b <- rev(a[1:k])
  b1 <- rev(a[(k+1):length(a)])
  b <- append(b,b1)
  return (b)
}


> a<-c(1,2,3,4,5)
> a
[1] 1 2 3 4 5
> k=2
> rotateK(a,k)
[1] 4 5 1 2 3

自定义的翻转函数

fanzhuan <- function(a,start,end)
{
  while(start < end)
  {
    temp = a[start]
    a[start] = a[end]
    a[end] = temp
    start = start + 1
    end = end - 1
  }
  return(a)
}


rotateK_1 <- function(a,k)
{
  if (is.null(a) || length(a) <= k)
  {
    return(a)
  }
  a <- fanzhuan(a,1,length(a))
  b <- fanzhuan(a,1,k)
  b1 <- fanzhuan(a,(k+1),length(a))
  b <- append(b[1:k],b1[(k+1):length(a)])
  return (b)
}





> a<-c(1,2,3,4,5)
> fanzhuan(a,1,5)
[1] 5 4 3 2 1
> rev(a)
[1] 5 4 3 2 1

两种方法的比较

k =2

> #k=2
> a<-c(1,2,3,4,5)
> k=2
> rotateK(a,k)
[1] 4 5 1 2 3
> #k=2
> k=2
> a<-c(1,2,3,4,5)
> rotateK_1(a,k)
[1] 4 5 1 2 3

k =3

> #k=3
> a<-c(1,2,3,4,5)
> k=3
> rotateK(a,k)
[1] 3 4 5 1 2
> #k=3
> k=3
> a<-c(1,2,3,4,5)
> rotateK_1(a,k)
[1] 3 4 5 1 2

k = 4

> #k=4
> a<-c(1,2,3,4,5)
> k=4
> rotateK(a,k)
[1] 2 3 4 5 1
> #k=4
> k=4
> a<-c(1,2,3,4,5)
> rotateK_1(a,k)
[1] 2 3 4 5 1

就这样解密了R语言中的rev源代码啦!~~~~

python

这里写代码片
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 来源:NumPy Tutorial - TutorialsPoint 译者:飞龙 协议:CC BY-NC-SA 4...
    布客飞龙阅读 33,007评论 6 98
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,556评论 25 708
  • 案例纪录 议题:两性关系 牌阵:从左到右依次为:现状、障碍(上面为内因、下面是外因)、资源和结果。 背景:案主是我...
    小小笨鸟可爱多阅读 283评论 0 1
  • 学乐器的课程会有很多种,而大多数的宣传通常只会强调优点,这使得很多人在课程的选择上都产生了不小的困惑和纠结。 尤其...
    芊语芊寻阅读 3,309评论 6 10
  • 不断往美食自制的新领域拓展,昨晚尝试烤面包,味道反响都不错哦! 刚烤出来是热乎乎的,特别香~ 发面是用的面包机,揉...
    Ivy猫猫阅读 287评论 1 2