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

有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数 。
代码如下:

package com.homework.lhh;

import java.util.Scanner;

public class Ex14 {
    @SuppressWarnings("resource")
    public static void main(String[] args) {
        System.out.print("请输入你要输入多少个数:");
        Scanner sc = new Scanner(System.in);
        int length = sc.nextInt();
        int[] array = new int[length];
        System.out.print("请输入 " + length + " 个数(空格键隔开):");
        for (int i = 0; i < array.length; i++) {
            array[i] = sc.nextInt();
        }
        System.out.print("你输入的数组为:");
        for (int i = 0; i < array.length; i++) {
            System.out.print(array[i] + " ");
        }
        System.out.println();
        System.out.print("请输入一个数(你希望数组往后移动多少位)m:");
        int m = sc.nextInt();
        /*
         * array = Arrays.copyOf(array, array.length + m);//数组进行扩容 for (int i =
         * 0; i < array.length; i++) { System.out.print(array[i]+" "); }
         */
        // 判断输入的m是否符合数组的长度
        while (true) {
            if (m > length - 1 || m < 0) {
                System.out.print("移动的位数不能大于数组的长度,请不能为负数!请重新输入:");
                m = sc.nextInt();
            } else {
                break;
            }
        }
        int[] newArray = new int[length];// 定义一个新的数组,与原来的数组长度相同
        for (int i = 0; i < length; i++) {
            newArray[i] = array[i];
        }
        for (int i = 0; i < length; i++) {
            int tmp = (i + m) % length;// 计算新的位置
            array[tmp] = newArray[i];
        }
        System.out.print("移动 " + m + " 个位置后,数组变为:");
        for (int i = 0; i < length; i++) {
            System.out.print(array[i] + " ");
        }
    }
}

运行结果如下:
Java-有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数 。_第1张图片

你可能感兴趣的:(Java)