m个元素的数组,随机选择n个不重复元素(js实现)
2016-01-09 21:21
996 查看
问题描述:
在由m个元素的source数组中,随机选择n个不重复的元素放入新数组target
注:source数组元素本身不重复,m>n
解决方案
方案一:根据数组source,在0到source.length-1范围内随机一个数作为下标,选择下标对应元素放入数组target
同1法,再从source数组随机一个数,将这个数与target数组中已有的数进行比较,不同则放入,相同则再随机
重复执行2,然后就能筛选出n个不同的数。
方案二:
根据数组source,在0到source.length-1范围内随机一个数作为下标,选择下标放入数组target
同1法,随机一个新的下标,将这个数与target数组中已有的数进行比较,不同则放入,相同则再随机
重复执行2,然后就能筛选出n个不同的数。
这个时候数组target都存放的是要选取的数的下标,我们根据下标转换成对应的source数组中的数即可
方案一和方案二的区别:
我们平时可能用方案一比较多,因为比较直观,但是分析表明,方案二是更好的。原因:方案一比较的是真实数据,方案二比较的是下标,所以方案二在比较存储时效率较高,且存储所占内存小。
方案二JavaScript代码
/** * source共10个元素 * 选择4个数据存储在target * */ (function(){ var source= [ "c","c++","php","html","css","javascript","java","jsp","asp","node" ]; var sL = source.length; var target= []; //存储下标 //随机4个数组下标 for(var i = 0; i < 4; i++){ var rand = Math.floor( Math.random() * sL ); if(target.length > 0){ detection(target, rand); }else{ target.push(rand); } } //检测num是否存在于arr,存在重新添加,不存在直接添加 function detection(arr, num){ var repeatFlag = false; for(var j = 0; j < arr.length; j++){ if(arr[j] == num){ repeatFlag = true; } } if(repeatFlag){ //递归 arguments.callee(arr, Math.floor( Math.random() * sL )); }else{ arr.push(num); } } //测试,输出target //for(var i=0; i<target.length; i++){ // console.log(source[target[i]]); //} })();
注释的代码,为测试的代码。
我也是优化了半天才想出的方法,很是(∩_∩),简单的问题不断从优解决,我们会更加进步。
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解
- call/apply/bind 的理解与实例分享
- 如何创建对象以及jQuery中创建对象的方式
- 数组方法汇总