w3resource

JavaScript: Get n random elements at unique keys from array up to the size of array

JavaScript fundamental (ES6 Syntax): Exercise-226 with Solution

n Random Unique Elements

Write a JavaScript program to get n random elements with unique keys from an array up to the size of the array.

  • Shuffle the array using the Fisher-Yates algorithm.
  • Use Array.prototype.slice() to get the first n elements.
  • Omit the second argument, n, to get only one element at random from the array.

Sample Solution:

JavaScript Code:

// Define a function 'sampleSize' to randomly sample elements from an array
const sampleSize = ([...arr], n = 1) => {
  let m = arr.length;
  
  // Shuffle the array using the Fisher-Yates algorithm
  while (m) {
    const i = Math.floor(Math.random() * m--);
    [arr[m], arr[i]] = [arr[i], arr[m]];
  }
  
  // Return a slice of the shuffled array with 'n' elements
  return arr.slice(0, n);
};

// Log the result of sampling 2 elements from an array
console.log(sampleSize([1, 2, 3], 2));  
// Log the result of sampling 4 elements from an array (exceeding the array length)
console.log(sampleSize([1, 2, 3], 4));

Output:

[3,2]
[2,3,1]

Visual Presentation:

JavaScript Fundamental: Get n random elements at unique keys from array up to the size of array.

Flowchart:

flowchart: Get n random elements at unique keys from array up to the size of array.

Live Demo:

See the Pen javascript-basic-exercise-226-1 by w3resource (@w3resource) on CodePen.


Improve this sample solution and post your code through Disqus

Previous: Write a JavaScript program to get n random elements at unique keys from array up to the size of array.
Next: Write a JavaScript program to remove elements from an array for which the given function returns false.

What is the difficulty level of this exercise?

Test your Programming skills with w3resource's quiz.



Become a Patron!

Follow us on Facebook and Twitter for latest update.

It will be nice if you may share this link in any developer community or anywhere else, from where other developers may find this content. Thanks.

https://www.w3resource.com/javascript-exercises/fundamental/javascript-fundamental-exercise-226.php