Как получить все подстроки (непрерывные подпоследовательности) моего массива JavaScript?

моя задача-разбить данный массив на меньшие массивы с помощью JavaScript. Например [1, 2, 3, 4] следует разделить на [1] [1, 2] [1, 2, 3] [1, 2, 3, 4] [2] [2, 3] [2, 3, 4] [3] [3, 4] [4].

Я использую этот код:

let arr = [1, 2, 3, 4];

for (let i = 1; i <= arr.length; i++) {
  let a = [];
  for (let j = 0; j < arr.length; j++) {
    a.push(arr[j]);
    if (a.length === i) {
      break;
    }
  }
  console.log(a);
}

и я получаю следующий результат: [1] [1, 2] [1, 2, 3] [1, 2, 3, 4] undefined

что я упускаю/делаю не так?

6 ответов


у вас есть две проблемы в коде:

  1. вам нужно иметь цикл для инициализации со значением i для внутреннего цикла, чтобы он рассматривал следующий индекс для новой итерации i
  2. вам нужно удалить это break на длине, которая у вас есть во внутреннем цикле.

let arr = [1, 2, 3, 4];
for (let i = 0; i <= arr.length; i++) {
  let a = [];
  for (let j = i; j < arr.length; j++) {
    a.push(arr[j]);
    console.log(a);
  }
}

для внутреннего массива вы можете просто начать с индекса внешнего массива.

var array = [1, 2, 3, 4],
    i, j, l = array.length,
    result = [];
    
for (i = 0; i < l; i++) {
    for (j = i; j < l; j++) {
        result.push(array.slice(i, j + 1));
    }
}
console.log(result.map(a => a.join(' ')));
.as-console-wrapper { max-height: 100% !important; top: 0; }

попробуй такое

 let arr = [1, 2, 3, 4];
       for (let i = 0; i <= arr.length; i++) {
          let a = [];
          for (let j = i; j < arr.length; j++) {
            a.push(arr[j]);    
              console.log(a);            
          }  
        }

Если вы не хотите мутировать свой массив.

    let arr = [1, 2, 3, 4];
    let res = [];
    for (let i = 0; i <= arr.length; i++) {
      let a = [];
      for (let j = i; j < arr.length; j++) {
        a = [...a, arr[j]];
        res = [...res, a];
      }
    }
 console.log(res);

Я готовить stackblitz для данного случая.

let source = [1,2,3,4];
const output = [];
const arrayMultiplier = (source) => {
  const eachValueArray = [];
  source.forEach((item, index) => {
    // Will push new array who will be sliced source array.
    eachValueArray.push(source.slice(0, source.length - index));
  });
  //We reverse array to have right order.
  return eachValueArray.reverse();
};

for(let i = 0; i <= source.length; i++) {
  output.push(...arrayMultiplier(source));
  source.shift();  // Will recraft source array by removing first index.
}
//Don't forget last item.
output.push(source);
console.log(output);

это не самое короткое решение, но сделать работу

= = обновление после просмотра кода ==

// [...]
const arrayMultiplier = (source) => {
    // Will push new array who will be sliced source array.
    // We reverse array to have right order.
  return source.map((item, index) => source.slice(0, source.length - index)).reverse();
};
// [...]

используйте две итерации

  1. получить массив среза на основе индекса цикла.
  2. используйте нарезанный массив и объедините элемент массива.

  var arr = [1, 2, 3, 4];
  let newArra =[];
  arr.map((x,i)=> {
       let remainArr = arr.slice(i);
       return remainArr.forEach((y, r) => newArra.push(remainArr.slice(0, r+1)))
  })
  newArra.forEach(x=> console.log(x))