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); } }

浙公网安备 33010602011771号