面试题:有一个多维数组,其维数不定。请写一个函数,找出该数组指定某个维度的项(注,这些项其本身也有可能是一个多维数组),然后把他们返回回来。(小提示:请用javascript语言实现)

如题:有一个多维数组,其维数不定。请写一个函数,找出该数组指定某个维度的项(注,这些项其本身也有可能是一个多维数组),然后把他们返回回来。(小提示:请用javascript语言实现)

function findDimensionItem(arr, dimension) {
    
    
  constresult = [];
  // 辅助函数,用于递归地查找指定维度的项
  function findItemHelper(arr, currDimension) {
    
    
    // 当前维度与指定维度相等时,将当前项添加到结果数组中
    if (currDimension === dimension) {
    
    
      result.push(...arr);
    } else {
    
    
      // 遍历当前项的每一项
      arr.forEach(item => {
    
    
        // 若当前项为数组,则递归调用 findItemHelper 函数进行下一维度的查找
        if (Array.isArray(item)) {
    
    
          findItemHelper(item, currDimension + 1);
        }
      });
    }
  }
  // 调用辅助函数开始查找
  findItemHelper(arr, 0);
  // 返回结果数组
  return result;
}

const arr = [["a",["b",["b"]],"c"],2,[3,4,[5,6,[7,8]]]];
console.log(findDimensionItem( arr , 0 ));  // [["a",["b",["b"]],"c"],2,[3,4,[5,6,[7,8]]]]
console.log(findDimensionItem( arr , 1 ));  // ["a",["b",["b"]],"c",3,4,[5,6,[7,8]]]
console.log(findDimensionItem( arr , 2 ));  // ["b",["b"],5,6,[7,8]]
console.log(findDimensionItem( arr , 3 ));  // ["b",7,8]

猜你喜欢

转载自blog.csdn.net/weixin_41636483/article/details/129031242