2

任何人都可以提出一个片段或一个简短的方法来解决这个问题:

array = [a,b,c,d,e,f]

currentIndex = 2;

getOffset(array,currentIndex,2); // 2+2 = 4 -> return 'e'

getOffset(array,currentIndex,-2); // -> return 'a'

getOffset(array,currentIndex,-3); // -> return 'f'

getOffset(array,currentIndex,-4); // -> return 'e'

getOffset(array,currentIndex, 5); // -> return 'b'

因此,如果目标索引大于 array.length 或 < 0 -> 模拟数组内部的循环并继续进入索引。

谁能帮我?我试过了,但得到了一个错误的脚本:(

泰!

4

3 回答 3

5

尝试这个:

function getOffset(arr,index, offset){   
    return arr[(arr.length+index+(offset%arr.length))%arr.length];
}
于 2012-06-22T09:33:31.660 回答
2

我想这应该可以解决问题:

function getOffset(arr,n,offset) {
   offset = offset || 0;
   var raw = (offset+n)%arr.length;
   return raw < 0 ? arr[arr.length-Math.abs(raw)] : arr[raw];
}

var arr = ["a", "b", "c", "d", "e", "f"];
getOffset(arr,-3,2); //=> 'f'
getOffset(arr,-3);   //=> 'd'
//but also ;~)
getOffset(arr,-56,2);  //=> 'a'
getOffset(arr,1024,2); //=> 'a'
于 2012-06-22T09:35:41.150 回答
0

使用模运算符:

function getOffset(arr, index, step) {
  return arr[(((index + step) % arr.length) + arr.length) % arr.length];
}
于 2012-06-22T09:18:51.200 回答