有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数

来自:互联网
时间:2020-10-23
阅读:

今天为大家分享java经典实例,有n个整数,使其前面各数顺序向后移m个位置,有需要的小伙伴可以参考一下:

1、题目要求:

有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数

2、程序代码:

public static void mAIn(String[] args) {
    System.out.print("请输入你要输入多少个数:");
    Scanner sc = new Scanner(System.in);
    int len = sc.nextInt();
    int[] arr = new int[len];
    System.out.print("请输入 " + len + " 个整数:");
    for (int i = 0; i < len; i++) {
        arr[i] = sc.nextInt();
    }
    System.out.print("你输入的数组为:");
    for (int i : arr) {
        System.out.print(i + " ");
    }
    System.out.println();
    System.out.print("请输入一个数(你希望数组往后移动多少位)m:");
    int m = sc.nextInt();
    // 判断输入的m是否符合数组的长度
    while (true) {
        if (m < len && m > 0) {
            break;
        }
        System.out.print("移动的位数不能大于数组的长度,请不能为负数!请重新输入:");
        m = sc.nextInt();
    }
    int[] newArray = new int[len];// 定义一个新的数组,与原来的数组长度相同
    for (int i = 0; i < len; i++) {
        newArray[i] = arr[i];
    }
    for (int i = 0; i < len; i++) {
        int tmp = (i + m) % len;// 计算新的位置
        arr[tmp] = newArray[i];
    }
    System.out.print("移动 " + m + " 个位置后,数组变为:");
    for (int i = 0; i < len; i++) {
        System.out.print(arr[i] + " ");
    }
}
返回顶部
顶部