当前位置:首页 > JAVA教程 >

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

发布时间:2023-10-26 09:29:38 作者:佚名 阅读:(11)

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

有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的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] + " ");
    }
}

以上就是云梦编程为大家介绍的有n个整数,使其前面各数顺序向后移m个位置的程序写法,了解更多相关文章请关注云梦编程网!

© 2023 - 云梦编程网 版权所有 鲁ICP备2021017318号-4