Como encontrar três números maiores em uma matriz?

0

Pergunta

Olá eu gostaria de encontrar o maior dos três números em uma matriz de ORDEM. Estou confuso como eu deveria implementar o último lógica onde eu tenho para mudar os índices da matriz de resultado com base em se o número atual na matriz de resultados é maior ou menor que o ciclo da matriz de itens.

    function findThreeLargestNumbers(array) {
  let result = [null, null, null];
  for (let i = 0; i < array.length; i++) {
    if (!result[2] || result[i] > result[2]) {
      for (let j = 0; i <= 2; i++) {
        if (j === 2) {
          result[j] = array[i]
        } else {
          result[j] = array[i + 1]
        }
      }
    }
  }
  return result
}


console.log(findThreeLargestNumbers([141, 1, 17, -7, -17, -27, 18, 541, 8, 7, 7]));
algorithm javascript
2021-11-24 00:43:28
1

Melhor resposta

2

Você pode simplesmente sort em ordem crescente e usar slice para obter a última 3 elementos como:

1) Quando você deseja que o resultado nos últimos 3 maiores em ordem crescente [18, 141, 541]

function findThreeLargestNumbers(array) {
  return [...array].sort((a, b) => a - b).slice(-3);
}

// [18, 141, 541]
console.log(findThreeLargestNumbers([141, 1, 17, -7, -17, -27, 18, 541, 8, 7, 7]));

2) Quando você deseja que o resultado nos últimos 3 maiores em ordem decrescente [541, 141, 18]

function findThreeLargestNumbers(array) {
  return [...array].sort((a, b) => b - a).slice(0, 3);
}

console.log(findThreeLargestNumbers([141, 1, 17, -7, -17, -27, 18, 541, 8, 7, 7]));

2021-11-24 00:50:39

Melhor ainda para clonar a matriz e obtenha as 3 últimas número. BTW, graças EDITADO
decpk

para clonar a matriz seria você usar espalhar operador ou para o ciclo e empurre a matriz vazia?
dev

@dev ... é operador não é transmitida de sintaxe. Gostaria de ir para spread sintaxe...
decpk

Em outros idiomas

Esta página está em outros idiomas

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................