码迷,mamicode.com
首页 > 移动开发 > 详细

数组中元素位置移动实现

时间:2018-08-28 11:25:07      阅读:627      评论:0      收藏:0      [点我收藏+]

标签:实现   就是   操作   length   位置   改变   sys   数组   new   

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

分析:实现移动其实就是对索引进行操作,数组元素没有改变,而索引值发生了改变,

合理运用%运算,原数组索引%len=原数组的索引——>(原数组索引+移动位数)%len=新数组索引

    public static void function01() {
        int[] array={2,3,4,6,7,9};
        //复制一个数组,用于数据的存放
        int [] arraycopy=Arrays.copyOf(array, array.length);
        System.out.println("原数组:");
        System.out.println(Arrays.toString(array));
        System.out.println("请输入要移动的位数:");
        Scanner sc=new Scanner(System.in);
        
        int moveNum=sc.nextInt();//移动的位数
        
        for (int i = 0; i < arraycopy.length; i++) {
            int move=(i+moveNum)%array.length;
            arraycopy[move]=array[i];
        }
        System.out.println(Arrays.toString(arraycopy));
        
        
    }

原数组:
[2, 3, 4, 6, 7, 9]
请输入要移动的位数:
3
[6, 7, 9, 2, 3, 4]

 

数组中元素位置移动实现

标签:实现   就是   操作   length   位置   改变   sys   数组   new   

原文地址:https://www.cnblogs.com/doudou2018/p/9546705.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!