JS實現(xiàn)隨機(jī)抽取三人
因為實驗室每周需要三人來做報告,所以用JS來做一個隨機(jī)抽取的頁面。
首先,先說一下需求。研二同學(xué)共5人,一人是單獨的一組,研一同學(xué)共9人,同時九人分為三組。所以共八組,每周報告的三人從八組中抽取,這三人不能有兩人或者兩人以上在同一組。
程序思路1
1.將研一的三組建成三個小的數(shù)組,從這三個數(shù)組里每組隨機(jī)抽取一人;
2. 將第一步里抽取出來的三人和研二的五人放在一起,組成一個新的數(shù)組,在從中隨機(jī)抽取三人;
3. 若隨機(jī)抽取的三人存在上述情況,則返回第一步,重新隨機(jī)抽取,直到不存在第二步的情況,然后輸出;
程序思路2
將實驗室所有人放在一個大的數(shù)組里,先從數(shù)組里隨機(jī)抽取三人;
將研一的三組建成三個小的數(shù)組,把隨機(jī)抽取出來的三人去循環(huán)判斷是否存在兩人或者兩人以上在同一組;
最后實現(xiàn)
本來以為思路一比較好做,做到后面發(fā)現(xiàn)判斷是否同一組再重新進(jìn)行函數(shù)運行,總是出現(xiàn)問題,選出來的三個人通過for循環(huán)去判斷,理論可以但是卻不能實現(xiàn),還需要我再仔細(xì)想想。思路一程序如下
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=[]; } } }
這里面還是存在一些問題,思路二可以正常實現(xiàn),下面是思路二的程序:
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(); }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
XHTML-Strict 內(nèi)允許出現(xiàn)的標(biāo)簽
XHTML-Strict 內(nèi)允許出現(xiàn)的標(biāo)簽...2006-12-12JS函數(shù)修改html的元素內(nèi)容,及修改屬性內(nèi)容的方法
下面小編就為大家?guī)硪黄狫S函數(shù)修改html的元素內(nèi)容,及修改屬性內(nèi)容的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10JavaScript股票的動態(tài)買賣規(guī)劃實例分析上篇
這篇文章主要介紹了JavaScript對于動態(tài)規(guī)劃解決股票問題的真題例舉講解。文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08JavaScript數(shù)組的定義及數(shù)字操作技巧
這篇文章主要介紹了JavaScript數(shù)組的定義及數(shù)字操作技巧的相關(guān)資料,需要的朋友可以參考下2016-06-06JavaScript使用Promise實現(xiàn)分批處理接口請求
當(dāng)我們在實際項目中遇到需要批量發(fā)起上百條接口請求怎么辦呢,本文就來為大家介紹一下JavaScript如何使用Promise實現(xiàn)分批處理接口請求,需要的小伙伴可以參考一下2023-11-11