CodeWars练习之反转数组

今天下午玩了一下CodeWars,在做第四题的时候突然反应过来,不应该只是把一道题解决了,还应该参考别人好的思路。比如说这一题反转数组,我花了好几行的代码,而别人只用一句就解决了。所以想要记录下来。

题目要求:

Object[] data = new Object[]{1, 2, 3, 4, 5};

rotate(data, 1)    =>    {5, 1, 2, 3, 4}
rotate(data, 2)    =>    {4, 5, 1, 2, 3}
rotate(data, 3)    =>    {3, 4, 5, 1, 2}
rotate(data, 4)    =>    {2, 3, 4, 5, 1}
rotate(data, 5)    =>    {1, 2, 3, 4, 5}

rotate(data, 0)    =>    {1, 2, 3, 4, 5}

rotate(data, -1)    =>    {2, 3, 4, 5, 1}
rotate(data, -2)    =>    {3, 4, 5, 1, 2}
rotate(data, -3)    =>    {4, 5, 1, 2, 3}
rotate(data, -4)    =>    {5, 1, 2, 3, 4}
rotate(data, -5)    =>    {1, 2, 3, 4, 5}

我的解法:

public class Rotator {

  public Object[] rotate(Object[] data, int n) {
    Object[] result=new Object[data.length];
      for (int i = 0; i < result.length; i++) {      
      int  index=(Math.abs(n)*result.length+i-n)%result.length;
      result[i]=data[index];
    }
      return result;
  }

}
之所以乘上n倍的长度,是因为如果不这样,在n的绝对值大于数组长度时会出错。

排名比较前面的解法:

import java.util.Arrays;
import java.util.Collections;

public class Rotator {

  public Object[] rotate(Object[] data, int n) {
    Collections.rotate(Arrays.asList(data), n);
    return data;
  }
}

其实我也不知道谁的比较好,可是看到他的代码就一句话,觉得超厉害的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值