Chinaunix首页 | 论坛 | 博客
  • 博客访问: 329505
  • 博文数量: 69
  • 博客积分: 2090
  • 博客等级: 大尉
  • 技术积分: 708
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-23 09:31
文章分类

全部博文(69)

文章存档

2012年(1)

2011年(4)

2010年(48)

2009年(14)

2008年(2)

我的朋友

分类: C/C++

2010-08-26 17:47:42

把一个含有n个元素的数组循环右移/左移k位。

下面是具体的算法
一、时间复杂度为O(N*N)的算法

void rightshift_1(int a[],int n,int k) //n为数组长度,k为数组右移的位数

{
    int i;
    int t;
    
    k = k % n;    

    while (k--)
    {
        t = a[n - 1];
        
        for (i = n - 1;i > 0;i--)
        {
            a[i] = a[i - 1];
        }
        
        a[0] = t;
    }
}


二、时间复杂度为O(N)的算法

void reverse(int a[],int left,int right) //将数组内a[left]到a[roght]的元素逆置

{
    int t;
    
    for (;left < right;left++,right--)
    {
        t = a[left];
        a[left] = a[right];
        a[right] = t;
    }
}

void rightshift_2(int a[],int n,int k)//实现循环右移

{
    k = k % n;
    reverse(a,0,n - k - 1);
    reverse(a,n - k,n - 1);
    reverse(a,0,n - 1);
}

例如:

abcde123循环右移3为

步骤1:将a[0]~a[4]逆置,得到edcba123

步骤2:将a[5]~a[7]逆置,得到edcba321

步骤3:将a[0]~a[7]逆置,得到123abcde


循环左移的算法和循环右移基本相同

阅读(1013) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~