有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] + " ");
}
}
}
运行结果如下: