首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

原生JS | 随机抽取不重复的数组元素 —— 有没有更好的方法?

HTML5学堂-码匠:从数组随机抽取不重复的元素,构成新数组,拥有多种方法,来看看你用的方法性能如何? 效果的功能需求 从一个数组当中,随机抽取数个元素,构成新数组,要求这些元素不能重复。...(即随机获取不重复的数组元素) 相关说明:在此处依照“构思难度”和“性能”两方面出发,提供了四种不同的实现方法。...方法1:较为“传统”的实现方法 基本实现思路 从第二次随机抽取的元素开始,需要将抽取的元素与当前新数组的已抽取元素相比较,如果相同,则重新抽取,并再次执行比较的操作。...交换法,最重要的是两个点,第一,每次当前元素会被数组末尾元素所替代。第二,每次随机数的范围越来越小,数组长度越来越短。...也就是说,我们只要保证当前元素被末尾元素替代,并不断减小随机数范围,“数组长度”和“数组末尾的元素值”是可以忽略的。

9.3K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    从列表数组随机抽取固定数量的元素组成新的数组或列表

    从列表数组随机抽取固定数量的元素组成新的数组或列表 1:python版本:python里面一行代码就能随机选择3个样本 >>> import random >>> mylist=list(range...那么jQuery怎么随机选出固定数组数组[1, 2, 3, 4, 5, 6, 7, 8, 9]的三个元素,并构造成新数组的?...charset="UTF-8"> <script src="http://code.jquery.com/jquery-1.8.0.min.<em>js</em>...arr<em>中</em>,<em>随机</em>返回num个不重复项 function getArrayItems(arr, num) { //新建一个<em>数组</em>,将传入的<em>数组</em>复制过来,用于运算,而不要直接操作传入的<em>数组</em>; var...; } else { //<em>数组</em><em>中</em>数据项取完后,退出循环,比如<em>数组</em>本来只有10项,但要求取出20项.

    6K10

    JS数组随机排序实现(原地算法sortshuffle算法)

    compare(a,b),a、b都是比较参数,当a-b>0 ,交换位置a-b=0,位置不变a-b<0,位置不变随机排序我们都会想到Math的random方法,具体实现如下,但是这样操作确有缺陷,理论很丰满...测试:测试某数据在数组各个位置的次数。...1、换牌逻辑:从一副牌抽取一张,与最后一张牌进行交换,放到最后证明该牌已经被随机抽选过,而被交换的牌就排在前面,就有机会被继续抽选。...随机抽取一张抽取的放置到最后位置最后位置的牌放置在随机抽取的位置let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10,11,12,13,14];funtion shuffle...,要除去这张牌,然后在剩下的牌中继续抽 } return temp}shuffle(arr)抽取的牌放置旁边在抽取的那副牌冲除去随机抽取的那张牌附:本文用到的JS基础本文用到数组方法基本介绍splice

    92520

    Linux文件随机抽取N行

    有时候需要从大文件随机抽取N行出来进行模拟,但是用python或者别的语言感觉不太方便,linux下直接分割感觉会更快捷。...一般可以考虑以下的方法: 1. shuf shuf -n100 filename # 从文件随机选取100行 2. sort sort -R filename | head -n100 -R参数是将文件随机顺序...'\t' '{print $2}' # 假如输出的内容只有一列 awk 'BEGIN{srand()} {print rand()"\t"$0}' filename 这一句话,strand()是设定随机数种子...,必须写在BEGIN才能正常运行;rand()是产生0到1之间的随机数。...第一列是产生的随机数。sort -nk 1是根据第一列排序,运行后输出: ? 因为种子不一样,所以结果与上图不同。 最后选取想要的行数,然后输出除了第一列的内容就可以了。

    8.7K20

    Js数组空位问题

    Js数组空位问题 JavaScript数组空位指的是数组的empty,其表示的是在该位置没有任何值,而且empty是区别于undefined的,同样empty也不属于Js的任何数据类型,并且在JavaScript...版本以及各种方法对于空位的处理也有不同,所以建议避免在数组中出现空位。...描述 在JavaScript的数组是以稀疏数组的形式存在的,所以当在某些位置没有值时,就需要使用某个值去填充。...当然对于稀疏数组在各种浏览器中会存在优化的操作,例如在V8引擎中就存在快数组与慢数组的转化,此外在V8对于empty的描述是一个空对象的引用。...在Js中使用Array构造器创建出的存在空位的问题,默认并不会以undefined填充,而是以empty作为值,需要注意的是,空位并不是undefined,undefined表示的是没有定义,但是本身undefined

    2.9K42

    java在数组中放入随机数_如何在Java随机播放数组

    参考链接: Java数组Array java在数组中放入随机数  There are two ways to shuffle an array in Java.  ...有两种方法可以在Java随机播放数组。    ...我们可以从数组创建一个列表,然后使用Collections类的shuffle()方法来对其元素进行随机排序。 然后将列表转换为原始数组。    ...请注意,Arrays.asList()仅适用于对象数组。 自动装箱的概念不适用于泛型 。 因此,您不能使用这种方法来为基元改组数组。     2.使用随机随机排列数组 (2....我们可以在for循环中遍历数组元素。 然后,我们使用Random类来生成随机索引号。 然后将当前索引元素与随机生成的索引元素交换。 在for循环的末尾,我们将有一个随机混排的数组

    1.4K00

    jsmap遍历数组对象_js遍历数组

    forEach()和map()都是遍历数组的方法,用法类似,但是还是有很大区别: 相同点:       1.都是循环遍历数组的每一项;       2.在遍历执行匿名函数都可以接收三个参数,分别为...不同点:       map():       根据遍历执行的匿名函数,对于原数组的每个值产生一个对应的值,并返回一个新的数组,存在一个映射关系,并且不会改变原数组,不会对空数组进行检测。...forEach的匿名函数使用,对于空数组则不会调用到匿名函数。...arr.forEach(function(i,index,arr){ sum += i; console.log("sum的值为:",sum); }) //执行5次,最终结果 10 ** js... map 遍历数组 ** map 方法会迭代数组的每一个元素,并根据回调函数来处理每一个元素,最后返回一个新数组

    19.6K30

    javascript数组怎么定义_js数组

    初识数组:新建一个数组 II....初识数组:新建一个数组 每一门编程语言,都有数组或类似数组的结构,同样的JavaScript(虽然是脚本语言)也不例外,学习JavaScript的数组,我们从新建第一个数组开始: var arr = [...(arr[1]) 赋值的方法也很简单,直接给数组对应的索引值的位置赋值即可与其他编程语言不同的是: JavaScript数组,长度是动态可变的,如果学过其他编程语言的朋友可能对这一点不是很习惯。...认识数组数组的基本方法 学会了新建数组和访问数组元素,我们开始了解一些数组的基本方法: push()方法 push(参数1,参数2,参数3…,参数n) 方法可把参数指定的元素依次添加到数组的末尾,...arr[0] + " " + arr[1] + " " + arr[2] + " " + arr[3] + " " + arr[4]); ---- slice()方法 slice() 方法返回包含从数组对象

    3.1K40

    JS特殊的对象-数组

    我想在一个变量存储多个值,应该如何存储? 所谓数组,就是将多个元素(通常是同一类型)按一定顺序排列放到一个集合,那么这个集合我们就称之为数组。...特别注意:JS不像PHP,没有关联数组. 1.2 获取数组元素 // 格式:数组名[下标] 下标又称索引 // 下标从0开始 // 功能:获取数组对应下标的那个值,如果下标不存在,则返回undefined..."pink"; 1.5 数组操作案例 案例1:求数组的所有数的和 //求和 var arr = [10, 20, 30, 40, 50]; //定义变量存储和 var sum = 0; for (var...i = 0; i < arr.length; i++) { sum += arr[i]; } console.log("和为:" + sum); 案例2:获取数组的最大值 //最大值 var...){ console.log(arr[i]); } } 案例4:将数组转为字符串并以 | 分割 //把数组的每个名字后面拼接一个|然后以字符串的方式输出 var names =

    9.1K00

    JS数组方法

    JS数组方法总结 Array.push() 向数组的末尾添加一个或者多个元素,并返回新的长度 let arr =[1,2,3]; console.log(arr.push(6)) //打印结果为...的指向,对数组进行循坏遍历,fn可传三个参数fn(item,[index],[arr]),item为遍历过程的当前元素,index为当前元素的下标,arr为原数组对象 let myArr = [1,2,3...this指向,因此如果想用thisValue参数必须使用function函数 Array.map() 对数组的每个元素进行重新编辑,返回用编辑结果组成的新数组,传递的参数和forEach()一样...,若数组没有元素符合要求则返回undefined,不改变原数组 let arr = [1,2,3] console.log(arr.find((item)=>{ return item>1 })...) //结果 2 Array.findIndex() 返回数组符合条件的第一个元素的下标,若数组没有元素符合要求则返回-1,不改变原数组 let arr = [1,2,3] console.log

    6.2K21

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券