今天为大家分享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] + " "); } }