p53 旋转数组 (将数组中的元素循环右移)(leetcode 189)

一:解题思路

第一种方法:新申请一个和原始数组一样大的新数组。先把要反转的数字拷贝到新数组中,然后把剩余的数字也拷贝到新数组中。最后把这个新数组全部拷贝到原始数组中来。Time:O(n),Space:O(n)

第二种方法:首先将整个数组反转,然后将旋转部分反转,最后将剩余部分反转。Time:O(n),Space:O(1)

 

C语言实现:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>


void right_shift_r(const char* src,char* result,unsigned int n)
{
    unsigned int N = strlen(src);
    int i=0;

    for(i=0;i<N;i++)
    {
        result[(i+n)%N] = src[i];
    }
    result[N]='\0';     
}

int main()
{
    char result[255]={0};

    right_shift_r("abcde",result,3); //cdeab

    printf("result = %s\n",result);

    right_shift_r("abcef",result,5); //abcef

    printf("result = %s\n",result);

    return 0;
}

  

二:完整代码示例 (C++版和Java版)

第三种方法C++:这种方法和上面C语言的方法一样。

class Solution {
public:
    void rotate(vector<int>& nums, int k) {
        if (nums.size() == 0 || k <= 0) return;
        int n = nums.size();
        vector<int> result(n,0);

        for (int i = 0; i < n; i++)
        {
            result[(i + k) % n] = nums[i];
        }
        for (int i = 0; i < n; i++)
        {
            nums[i] = result[i];
        }
    }
};

 

第一种方法C++:

class Solution {
public:
    void rotate(vector<int>& nums, int k) 
    {
        if (nums.size() == 0 || k <= 0) return;
        int n = nums.size();
        int m = k % n;
        int i = 0;
        vector<int> t(n,0);

        for (int j = n - m; j < n; j++) t[i++] = nums[j];
        for (int j = 0; j < n - m; j++) t[i++] = nums[j];
        for (int j = 0; j < n; j++) nums[j] = t[j];
    }
};

第一种方法Java:

class Solution {
    public void rotate(int[] nums, int k)
    {
          if(nums==null||nums.length==0||k<=0) return;
          int n=nums.length;
          int m=k%n;
          int[] t=new int[n];
          int i=0;

          for(int j=n-m;j<n;j++) t[i++]=nums[j];
          for(int j=0;j<n-m;j++) t[i++]=nums[j];
          for(int j=0;j<n;j++) nums[j]=t[j];
    }
}

第二种方法C++:

class Solution {
public:
    void reverse(vector<int>& nums, int i, int j)
    {
        for (; i < j; i++, j--)
        {
            int temp = nums[i];
            nums[i]=nums[j];
            nums[j] = temp;
        }
    }

    void rotate(vector<int>& nums, int k) 
    {
        if (nums.size() == 0 || k <= 0) return;
        int n = nums.size();
        int m = k % n;

        reverse(nums,0,n-1);
        reverse(nums,0,m-1);
        reverse(nums,m,n-1);
    }
};

第二种方法Java:

class Solution {
    private void reverse(int[] nums,int i,int j)
    {
        for(;i<j;i++,j--)
        {
            int temp=nums[i];
            nums[i]=nums[j];
            nums[j]=temp;
        }
    }
    
    public void rotate(int[] nums, int k)
    {
          if(nums==null||nums.length==0||k<=0) return;
          int n=nums.length;
          int m=k%n;
         
          reverse(nums,0,n-1);
          reverse(nums,0,m-1);
          reverse(nums,m,n-1);
    }
}

 

posted @ 2020-03-17 22:01  repinkply  阅读(203)  评论(0)    收藏  举报