Rotate Array

题目详情:https://leetcode.com/problems/rotate-array/description/
自己写的代码:

class Solution(object):
    def rotate(self, nums, k):
        """
        :type nums: List[int]
        :type k: int
        :rtype: void Do not return anything, modify nums in-place instead.
        """
        numsLenght=len(nums)
        k=k%numsLenght #这是后来加上的,一开始没有意识到k有可能大于numsLength
        if k==0: #如果k==0,那么直接返回
            print nums
            return
        diff=numsLenght-k #得到前边有多少元素需要往后移
        temp=nums[diff:numsLenght] #把后边的元素,存储下来
        i=diff-1 #因为下标从0开始,一共有diff个元素需要移动,最后一个元素为diff-1
        while i>=0:#先将前边的元素往后移动
            nums[i+k]=nums[i]
            i-=1
        i=0
        while i<k: #再将后边的元素移动前边
            nums[i]=temp[i]
            i=i+1
        print nums

模仿别人写的代码:

class Solution(object):
    def rotate(self, nums, k):
        """
        :type nums: List[int]
        :type k: int
        :rtype: void Do not return anything, modify nums in-place instead.
        """
        numsLength=len(nums)
        k=k%numsLength;
        nums[:]=nums[-k:]+nums[:-k]
        print nums

看见解析2(https://leetcode.com/problems/rotate-array/solution/)后

#include <sys/malloc.h>
void rotate(int* nums, int numsSize, int k)
{
  int *temp=(int*)malloc(sizeof(int)*numsSize);
  for(int i=0;i<numsSize;++i)
  {
    temp[(i+k)%numsSize]=nums[i]; //主要想联系一下temp数组的写法
  }
  for(int i=0;i<numsSize;++i)
  {
    nums[i]=temp[i];
    printf("%d ",temp[i]);
  }
  printf("\n" );
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值