作者:佚名 时间:2023-10-26 09:29:38 阅读:(13)
今天云梦编程为大家分享java经典实例,有n个整数,使其前面各数顺序向后移m个位置,有需要的小伙伴可以参考一下:
有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数
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个位置的程序写法,了解更多相关文章请关注云梦编程网!