金狮镖局 Design By www.egabc.com
因为实验室每周需要三人来做报告,所以用JS来做一个随机抽取的页面。
首先,先说一下需求。研二同学共5人,一人是单独的一组,研一同学共9人,同时九人分为三组。所以共八组,每周报告的三人从八组中抽取,这三人不能有两人或者两人以上在同一组。
程序思路1
1.将研一的三组建成三个小的数组,从这三个数组里每组随机抽取一人;
2. 将第一步里抽取出来的三人和研二的五人放在一起,组成一个新的数组,在从中随机抽取三人;
3. 若随机抽取的三人存在上述情况,则返回第一步,重新随机抽取,直到不存在第二步的情况,然后输出;
程序思路2
将实验室所有人放在一个大的数组里,先从数组里随机抽取三人;
将研一的三组建成三个小的数组,把随机抽取出来的三人去循环判断是否存在两人或者两人以上在同一组;
最后实现
本来以为思路一比较好做,做到后面发现判断是否同一组再重新进行函数运行,总是出现问题,选出来的三个人通过for循环去判断,理论可以但是却不能实现,还需要我再仔细想想。思路一程序如下
for (var i=0;i<3;i++) { index1 = Math.round(Math.random()*(array.length-1)); value = array[index1]; newarray.push(value); array.splice(index1,1); value =''; } console.log(newarray); for (var j =0;j<newarray.length;j++) { for (var m = 0; m < arr1.length; m++) { if (newarray[j] === arr1[m]){ num1++; } } for (var n = 0; n < arr2.length; n++) { if (newarray[j] === arr2[n]){ num2++; } } for (var o = 0; o < arr3.length; o++) { if (newarray[j] === arr3[o]){ num3++; } } } btn.onclick = function (){ var id = setInterval(frame,500); function frame() { if (!flag) { clearInterval(id); flag=true; } else { Begin(); document.getElementById("name").innerHTML=""; for (var i = 0; i < newarray.length; i++) { document.getElementById("name").innerHTML += newarray[i] + "</br> "; } flag=false; newarray=[]; } } }
这里面还是存在一些问题,思路二可以正常实现,下面是思路二的程序:
function Begin() { num1 = Math.round(Math.random() * (arr4.length - 1)); num2 = Math.round(Math.random() * (arr4.length - 1)); num3 = Math.round(Math.random() * (arr4.length - 1)); Begin2(); } function Begin2() { var array = []; var arrayLast = []; if (num1 !== num2 && num1 !== num3 && num2 !== num3) { array.push(num1); array.push(num2); array.push(num3); for (var i = 0; i < array.length; i++) { if (typeof arr4[array[i]] === "string") { arrayLast.push(arr4[array[i]]); } else { var num4 = Math.round(Math.random() * (arr4[array[i]].length - 1)); arrayLast.push(arr4[array[i]][num4]); } } } else { Begin(); } console.log(arrayLast); document.getElementById("name").innerHTML=""; for (var i = 0; i < arrayLast.length; i++) { document.getElementById("name").innerHTML += arrayLast[i] + "</br> "; } } btn.onclick = function () { Begin(); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
金狮镖局 Design By www.egabc.com
金狮镖局
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
金狮镖局 Design By www.egabc.com
暂无JS实现随机抽取三人的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2025年01月18日
2025年01月18日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]