freeCodeCamp/curriculum/challenges/espanol/02-javascript-algorithms-an.../basic-data-structures/check-for-the-presence-of-a...

2.7 KiB

id title challengeType forumTopicId dashedName
587d7b7b367417b2b2512b14 Comprueba la presencia de un elemento con indexOf() 1 301154 check-for-the-presence-of-an-element-with-indexof

--description--

Ya que los arreglos pueden modificarse, o mutarse, en cualquier momento, no se puede garantizar dónde estará un dato concreto en un arreglo determinado, o si ese elemento sigue existiendo. Afortunadamente, JavaScript nos proporciona otro método incorporado, indexOf(), que nos permite comprobar rápida y fácilmente la presencia de un elemento en un arreglo. indexOf() toma un elemento como parámetro, y cuando lo llama, devuelve la posición, o índice, de ese elemento, o -1 si el elemento no existe en el arreglo.

Por ejemplo:

let fruits = ['apples', 'pears', 'oranges', 'peaches', 'pears'];

fruits.indexOf('dates');
fruits.indexOf('oranges');
fruits.indexOf('pears');

indexOf('dates') devuelve -1, indexOf('oranges') devuelve 2, e indexOf('pears') devuelve 1 (el primer índice en el que existe cada elemento).

--instructions--

indexOf() puede ser increíblemente útil para verificar rápidamente la presencia de un elemento en un arreglo. Hemos definido una función, quickCheck, que toma un arreglo y un elemento como argumentos. Modifica la función usando indexOf() para que devuelva true si el elemento pasado existe en el arreglo, y false si no existe.

--hints--

La función quickCheck debe devolver un valor booleano (true o false), no una cadena ("true" o "false")

assert.isBoolean(quickCheck(['squash', 'onions', 'shallots'], 'mushrooms'));

quickCheck(["squash", "onions", "shallots"], "mushrooms") debe devolver false

assert.strictEqual(
  quickCheck(['squash', 'onions', 'shallots'], 'mushrooms'),
  false
);

quickCheck(["onions", "squash", "shallots"], "onions") debe devolver true

assert.strictEqual(
  quickCheck(['onions', 'squash', 'shallots'], 'onions'),
  true
);

quickCheck([3, 5, 9, 125, 45, 2], 125) debe devolver true

assert.strictEqual(quickCheck([3, 5, 9, 125, 45, 2], 125), true);

quickCheck([true, false, false], undefined) debe devolver false

assert.strictEqual(quickCheck([true, false, false], undefined), false);

La función quickCheck debe utilizar el método indexOf()

assert.notStrictEqual(quickCheck.toString().search(/\.indexOf\(/), -1);

--seed--

--seed-contents--

function quickCheck(arr, elem) {
  // Only change code below this line

  // Only change code above this line
}

console.log(quickCheck(['squash', 'onions', 'shallots'], 'mushrooms'));

--solutions--

function quickCheck(arr, elem) {
  return arr.indexOf(elem) >= 0; 
}