遍历一个数组n次并旋转其中的元素
创始人
2024-12-04 16:00:47
0

我们可以将数组中的元素截取成不同的段,然后对它们分别进行旋转并拼接在一起形成一个新的数组。

Python 代码示例:

def rotate_array(arr, n):
    length = len(arr)
    # 如果 n 大于数组长度,需要对 n 取模
    n = n % length 
    # 将数组切割成两段,各自进行翻转
    first_part = arr[:length-n][::-1]
    second_part = arr[length-n:][::-1]
    # 拼接两段并逆向输出
    return (first_part + second_part)[::-1]

arr = [1, 2, 3, 4, 5]
n = 2
print(rotate_array(arr, n))  # 输出 [4, 5, 1, 2, 3]

Java 代码示例:

public static int[] rotateArray(int[] arr, int n) {
    int length = arr.length;
    // 如果 n 大于数组长度,需要对 n 取模
    n = n % length; 
    int[] result = new int[length];
    // 将数组切割成两段,各自进行翻转
    int[] firstPart = Arrays.copyOfRange(arr, 0, length - n);
    int[] secondPart = Arrays.copyOfRange(arr, length - n, length);
    reverseArray(firstPart);
    reverseArray(secondPart);
    // 合并两段翻转后的数组,然后再次翻转
    System.arraycopy(secondPart, 0, result, 0, n);
    System.arraycopy(firstPart, 0, result, n, length - n);
    reverseArray(result);
    return result;
}

// 翻转数组
public static void reverseArray(int[] arr) {
    int left = 0, right = arr.length - 1;
    while (left < right) {
        int temp = arr[left];
        arr[left] = arr[right];
        arr[right] = temp;
        left++;
        right--;
    }
}

public static void main(String[] args) {
    int[] arr = {1, 2, 3, 4, 5};
    int n = 2;
    int[] result = rotateArray(arr,n);
    System.out.println(Arrays.toString(result));  // 输出 [4, 5, 1, 2, 3]
}

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...