Unique Random Array Javascript
Solution 1:
Here's a core function for creating N random numbers between a min and max value.
functionrandCalc(maxVal, minVal, numRandoms) {
var max = Math.max(maxVal, minVal);
var min = Math.min(maxVal, minVal);
// create a set to keep track of numbers we've already used so// we don't repeat any random numbersvar set = {};
var randoms = [];
var rand;
// prevent infinite loop if not given enough rangeif (max - min < numRandoms) {
return randoms;
}
while (randoms.length < numRandoms) {
rand = Math.floor((Math.random() * (max - min + 1) + min));
// if we haven't already used this random number// then put it in our output array and add it to the setif (!(rand in set)) {
randoms.push(rand);
set[rand] = true;
}
}
return randoms;
}
This function has nothing to do with the DOM or any particular limits of your problem. You can then wrap this with another function that retrieves info from the DOM, checks to see if everything is in range and then calls this core function.
functionmakeRandoms() {
// retrieve DOM values and convert them to numbersvar maxVal = document.getElementById("maxRange").value;
var minVal = document.getElementById("minRange").value;
if (!maxVal || !minVal) {
alert("You must specify both a minimum and maximum value");
return;
}
// convert both to numbers
maxVal = parseInt(maxVal, 10);
minVal = parseInt(minVal, 10);
if (minVal < 1) {
alert("The min value cannot be lower then 1");
return;
}
if (maxVal > 37) {
alert("The higher value cannot be higher then 37");
return;
}
if (maxVal - minVal < 6) {
alert("The difference cannot be lower then 6");
return;
}
var randoms = randCalc(maxVal, minVal, 6);
// output the randoms array heredocument.getElementById("output").innerHTML = JSON.stringify(randoms);
}
This makes a reusable function for generating N random values and keeps that utility function completely separate from your code that accesses the DOM in one particular page. Because of the way this uses a set to keep track of the used random numbers, this is scalable to very large numeric ranges or very large numbers of random numbers when some other algorithms that prebuild a list of all possible outputs are not as scalable.
Working demo: http://jsfiddle.net/jfriend00/48kCg/
Solution 2:
Here is a JS function, more simple, that does what you pretend:
functionrandCalc(maxVal,minVal){
var text = "";
var possible = [];
for(var i = minVal; i < maxVal; i++){
possible.push(i);
}
for( var i=0; i < 6; i++ ){
if(text.length == 6){
return text;
}
text += possible[Math.floor(Math.random() * possible.length)];
if(text > 6){
text = text.substring(0, 6);
}
}
return text;
}
Solution 3:
It all looks pretty complicated. You can create an array with [n
] random numbers between 0 and [max
] using:
functioncreateArrayWithUniqueRandomNumbers(n, max) {
var checkobj = {}
,arr = [];
while (arr.length < n) {
var x = Math.floor(Math.random()*(max+1));
if (!(x in checkobj)) {
checkobj[x] = 1;
arr.push(x);
}
}
//sorting for conveniencereturn arr.sort(function(a,b){return a-b;});
}
// usagevar myarr = createArrayWithUniqueRandomNumbers(6, 37);
Post a Comment for "Unique Random Array Javascript"