【三次翻转】旋转数组

求解代码

java 复制代码
public int[] solve(int n, int m, int[] a) {
        m %= n;
        reverse(a, 0, n - 1);
        reverse(a, 0, m - 1);
        reverse(a, m, n - 1);
        return a;
    }

    private void reverse(int[] arr, int start, int end) {
        while (start < end) {
            swap(arr, start++, end--);
        }

    }

    private void swap(int[] arr, int i, int j) {
        int tmp = arr[i];
        arr[i] = arr[j];
        arr[j] = tmp;
    }

小贴士

因为右移 n 位 = 没动右移 n + k 位 = 右移 k 位

所以,要通过取余操作把 m 压缩到 [0, n-1] 范围。

相关推荐
yongui4783413 分钟前
C# 与三菱PLC通讯解决方案
开发语言·c#
2501_9333295515 分钟前
技术架构深度解析:Infoseek舆情监测系统的全链路设计与GEO时代的技术实践
开发语言·人工智能·分布式·架构
大数据新鸟16 分钟前
操作系统之虚拟内存
java·服务器·网络
Tong Z18 分钟前
常见的限流算法和实现原理
java·开发语言
凭君语未可21 分钟前
Java 中的实现类是什么
java·开发语言
He少年23 分钟前
【基础知识、Skill、Rules和MCP案例介绍】
java·前端·python
wearegogog12324 分钟前
离散系统参数辨识与广义预测控制MATLAB实现
开发语言·matlab
史迪仔011226 分钟前
[QML] QML IMage图像处理
开发语言·前端·javascript·c++·qt
克里斯蒂亚诺更新33 分钟前
myeclipse的pojie
java·ide·myeclipse