首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何像在旋转木马中那样通过特定的索引获取未来的项目和过去的项目

如何像在旋转木马中那样通过特定的索引获取未来的项目和过去的项目
EN

Stack Overflow用户
提问于 2020-11-13 07:40:17
回答 1查看 59关注 0票数 0

我在试着创造一个定制的旋转木马。

我被这个算法困住了。

我需要得到未来和过去的项目通过特定的索引。

旋转木马可以无限地移动。

例: var exampleArray = 1,2,3,4,5,6,7,8,9;

切片(exampleArray,0)->> currentItem = 1,futureItems = 2,3,4,5,pastItems = 6,7,8,9

切片(exampleArray,4);->> currentItem = 5,futureItems = 6,7,8,9,pastItems = 1,2,3,4

切片(exampleArray,7);->> currentItem = 8,futureItems = 9,1,2,3,pastItems = 4,5,6,7

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-11-13 08:03:12

您可以使用this question的解决方案之一(我喜欢@mickmackusa)旋转数组,使所需的currentItem进入中间;然后只需将中间的切片作为pastItems,中间的元素作为currentItem,中间的切片作为futureItems

代码语言:javascript
复制
const slicer = (arr, idx) => {
  let len = arr.length;
  let mid = Math.floor(len/2);
  let rotated = arr.slice(0);
  rotated = rotated.concat(rotated.splice(0, (mid + idx + 1) % len));
  return [rotated.slice(0, mid), [rotated[mid]], rotated.slice(mid+1)]
}

const exampleArray = [1,2,3,4,5,6,7,8,9];

[pastItems, currentItem, futureItems] = slicer(exampleArray, 0);
console.log(pastItems);
console.log(currentItem);
console.log(futureItems);

[pastItems, currentItem, futureItems] = slicer(exampleArray, 4);
console.log(pastItems);
console.log(currentItem);
console.log(futureItems);

[pastItems, currentItem, futureItems] = slicer(exampleArray, 7);
console.log(pastItems);
console.log(currentItem);
console.log(futureItems);

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64817120

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档