JavaScript中的递归问题Snail Trail

假设我们有一个像这样的数组-

const arr = [
   [1, 2, 3, 4],
   [12,13,14,5],
   [11,16,15,6],
   [10,9, 8, 7]
];

该数组绑定为一个正方形矩阵。

我们需要编写一个JavaScript函数,该函数接受此数组,并通过获取元素并不断旋转直到其收敛到中心来构造一个新的数组。蜗牛的踪迹绕着矩阵的外部向内盘旋。

因此,上述数组的输出应为-

const output = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16];

我们将使用递归解决此问题。

示例

以下是代码-

const arr = [
   [1, 2, 3, 4],
   [12,13,14,5],
   [11,16,15,6],
   [10,9, 8, 7]
];
const spiralForm = arr => {
   return arr.length > 1 ?
   arr.splice(0,1)[0]
   .concat(spiralForm(arr[0].map((c, i) => {
      return arr.map(r => r[i]);
   })
   .reverse())) :
   arr[0]
}
console.log(spiralForm(arr));

输出结果

这将在控制台上产生以下输出-

[
  1,  2,  3,  4,  5,  6,
  7,  8,  9, 10, 11, 12,
 13, 14, 15, 16
]