美文网首页
LeetCode 189.旋转数组

LeetCode 189.旋转数组

作者: 饼干不干 | 来源:发表于2019-06-07 22:13 被阅读0次

    给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数。

    示例 1:
    输入: [1,2,3,4,5,6,7] 和 k = 3
    输出: [5,6,7,1,2,3,4]
    解释:
    向右旋转 1 步: [7,1,2,3,4,5,6]
    向右旋转 2 步: [6,7,1,2,3,4,5]
    向右旋转 3 步: [5,6,7,1,2,3,4]
    示例 2:
    输入: [-1,-100,3,99] 和 k = 2
    输出: [3,99,-1,-100]
    解释: 
    向右旋转 1 步: [99,-1,-100,3]
    向右旋转 2 步: [3,99,-1,-100]
    

    C

    void reverse1(int* a,int s,int e)
    {
        while(s<e)
        {
            int temp=a[e];
            a[e]=a[s];
            a[s]=temp;
            e--;
            s++;
        }
    }
    
    void rotate(int* nums, int numsSize, int k){
       if(k>=numsSize)
            k%=numsSize;
        if(k!=0)
        {
            reverse1(nums,0,numsSize-k-1);
            reverse1(nums,numsSize-k,numsSize-1);
            reverse1(nums,0,numsSize-1);
        }
    }
    

    相关文章

      网友评论

          本文标题:LeetCode 189.旋转数组

          本文链接:https://www.haomeiwen.com/subject/axavxctx.html