JavaScript中生成不同类型与范围随机数的多种技巧汇总

网络 2024-08-06 18:12:49编程技术
255

JavaScript 是一种功能强大的编程语言,广泛应用于网页开发、游戏制作和各种计算任务中。生成随机数是编程中的一个常见需求,无论是在开发简单的浏览器游戏、进行数据模拟,还是在安全性要求较高的场景中,掌握如何生成不同类型与范围的随机数都是至关重要的。本文将深入探讨 JavaScript 中生成随机数的各种技巧,从基本的Math.random()函数到更高级的算法,帮助读者全面了解并掌握这一核心技能。

Javascript.jpg

1,生成 [ 0, 1 ) 范围内的随机数(大于等于0,小于1)

(1)使用 random() 方法可以返回一个介于 0 ~ 1 之间的伪随机数(包括 0,不包括 1)。

Math.random()

(2)下面是一个测试样例

var random = Math.random();
console.log(random);

2,生成 [ n, m ) 范围内的随机数(大于等于n,小于m)

(1)这种最简单,因为和 random 的特点保持一致。只需使用如下公式即可:

Math.random()*(m-n)+n

(2)比如下面生成 [10,15) 范围内的随机浮点数。

var random1 = Math.random()*(15-10)+10;
var random2 = Math.random()*(15-10)+10;
var random3 = Math.random()*(15-10)+10;
console.log(random1);
console.log(random2);
console.log(random3);

3,生成 [n,m]、(n,m)、(n,m] 范围内的随机数

因为 random 的特点,要取得这几个区间内的浮点数稍微麻烦些,需要借助一些判断才能满足要求。

//取得[n,m]范围随机数
function fullClose(n,m) {
   var result = Math.random()*(m+1-n)+n;
   while(result>m) {
       result = Math.random()*(m+1-n)+n;
   }
   return result;
}
 
//取得(n,m)范围随机数
function fullOpen(n,m) {
   var result = Math.random()*(m-n)+n;
   while(result == n) {
       result = Math.random()*(m-n)+n;
   }
   return result;
}
 
//取得(n,m]范围随机数
function leftOpen(n,m) {
   var result = Math.random()*(m-n+1)+n-1;
   while(result<n) {
       result = Math.random()*(m-n+1)+n-1;
   }
   return result;
}

随机整数的生成

要生成随机整数,我们还需要借助如下两个方法: Math.round(num):将 num 四舍五入取整 Math.floor(num):将 num 向下取整,即返回 num 的整数部分。当然我们也可以使用 parseInt() 方法代替。

1,随机生成 0、1 这两个整数

(1)下面这个方法可以随机获取 0 或 1,它们获取到的几率是比较均衡的。

Math.round(Math.random())

(2)下面是一个测试样例

var random1 = Math.round(Math.random());
var random2 = Math.round(Math.random());
var random3 = Math.round(Math.random());
console.log(random1);
console.log(random2);
console.log(random3);

2,生成 [ 0, n ) 范围内的随机整数(大于等于0,小于n)

(1)下面方法生成一个 0 到 n-1 的随机整数(这 n 个数获取几率都是均衡的)

Math.floor(Math.random()*n)

(2)比如下面生成几个 0 到 4 的随机整数(包括 0 和 4)。

var random1 = Math.floor(Math.random()*5);
var random2 = Math.floor(Math.random()*5);
var random3 = Math.floor(Math.random()*5);
console.log(random1);
console.log(random2);
console.log(random3);

3,生成 [ 1, n ] 范围内的随机整数(大于等于1,小于等于n)

(1)下面方法生成一个 1 到 n 的随机整数(这 n 个数获取几率都是均衡的)

Math.floor(Math.random()*n)+1

(2)比如下面生成几个 1 到 5 的随机整数(包括 1 和 5)。

var random1 = Math.floor(Math.random()*5)+1;
var random2 = Math.floor(Math.random()*5)+1;
var random3 = Math.floor(Math.random()*5)+1;
console.log(random1);
console.log(random2);
console.log(random3);

4,生成 [ min, max ] 范围内的随机整数(大于等于min,小于等于max)

(1)下面方法生成一个最小值为 min,最大值为 max 的随机整数。

Math.floor(Math.random()*(max-min+1))+min

(2)比如下面生成几个 5 到 10 的随机整数

var random1 = Math.floor(Math.random()*5)+1;
var random2 = Math.floor(Math.random()*5)+1;
var random3 = Math.floor(Math.random()*5)+1;
console.log(random1);
console.log(random2);
console.log(random3);

随机字符串的生成

1,生成指定位数的纯数字字符串

//生成n位数字字符串
function randomNum(n){
  var res = "";
  for(var i=0;i<n;i++){
    res += Math.floor(Math.random()*10);
  }
  return res;
}
 
//测试
console.log(randomNum(3))
console.log(randomNum(5))
console.log(randomNum(7))

2,生成指定位数的数字字母混合的字符串

//生成n位数字字母混合字符串
function generateMixed(n) {
  var chars = ['0','1','2','3','4','5','6','7','8','9',
              'A','B','C','D','E','F','G','H','I','J','K','L','M',
              'N','O','P','Q','R','S','T','U','V','W','X','Y','Z'];
  var res = "";
  for(var i = 0; i < n ; i++) {
     var id = Math.floor(Math.random()*36);
     res += chars[id];
  }
  return res;
}
 
//测试
console.log(generateMixed(3))
console.log(generateMixed(5))
console.log(generateMixed(7))

对比上面代码的补充版,加入 数字、大小写字符

function getjl(n){
var chas=["0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z"];
var binint=["0","1","2","3","4","5","6","7","8","9"];
var res="";
for(var i=0; i < n; i++){
		var id = Math.floor(Math.random() * 62);
		res+=chas[id];
	}
						
return res;
}
//测试
console.log(getjl(3))
console.log(getjl(5))
console.log(getjl(7))

总结

通过本文的学习,我们深入了解了JavaScript中生成随机数的多种方法,包括生成不同范围的整数、浮点数以及符合特定分布的随机数。这些技巧不仅满足了常见的需求,也为解决复杂问题提供了有力工具。无论是用于游戏开发、数据分析还是其他需要随机性的应用场景,掌握这些方法都将使你的编程能力更加全面和强大。希望本文的内容能够为你的JavaScript编程之旅提供宝贵的帮助。

JavaScript 随机数 random
THE END
战地网
频繁记录吧,生活的本意是开心

相关推荐

Excel中使用公式实现随机数生成的方法详解
在数据处理和分析过程中,随机数生成是一个常见的需求。Excel作为一款强大的数据处理工具,提供了多种方法来生成随机数。本文ZHANID工具网将详细介绍在Excel中使用公式生成随...
2025-01-30 电脑知识
130

JavaScript中forEach的几种用法详解
在处理数组时,JavaScript 提供了许多内置方法,其中 forEach 是最常用的方法之一。forEach 方法为数组中的每个元素执行一次提供的函数,使得遍历数组变得简单而高效。本文将...
2025-01-17 编程技术
164

JavaScript中Object.keys()的用法示例详解
在JavaScript中,Object.keys()方法是一个功能强大的工具,它允许开发者获取对象的所有可枚举属性名,并以数组的形式返回。这一特性使得Object.keys()在处理对象属性、字符串...
2025-01-04 编程技术
165

JavaScript中检查字符串是否包含某个字符的5种方法详解
在JavaScript编程中,检查字符串是否包含某个特定字符是一个常见的操作。无论是验证输入、处理文本,还是进行数据过滤,这一功能都具有广泛的应用场景。本文将介绍几种常用的...
2025-01-02 编程技术
200

HTML+JavaScript实现在线网页版扫雷游戏示例代码详解
​扫雷游戏是一款经典的益智游戏,通过点击方块揭示其是否为地雷,同时根据周围地雷的数量进行推断,最终成功避开所有地雷。下面,我们将通过HTML和JavaScript来实现一个基本...
2024-12-27 编程技术
212

Python中生成随机整数的利器:numpy.random.randint()函数详解
在数据科学和机器学习领域,生成随机数是常见的需求之一。Python的NumPy库提供了强大的工具来生成各种类型的随机数。本文将详细介绍numpy.random.randint()函数,该函数可以生...
2024-12-24 编程技术
202