js獲取數(shù)組任意個不重復的隨機數(shù)組元素 原創(chuàng)
原創(chuàng) 更新時間:2010年03月15日 20:38:25 原創(chuàng) 作者:
新建一個數(shù)組,將傳入的數(shù)組復制過來,用于運算,而不要直接操作傳入的數(shù)組
復制代碼 代碼如下:
<script language="javascript">
//從一個給定的數(shù)組arr中,隨機返回num個不重復項
function getArrayItems(arr, num) {
//新建一個數(shù)組,將傳入的數(shù)組復制過來,用于運算,而不要直接操作傳入的數(shù)組;
var temp_array = new Array();
for (var index in arr) {
temp_array.push(arr[index]);
}
//取出的數(shù)值項,保存在此數(shù)組
var return_array = new Array();
for (var i = 0; i<num; i++) {
//判斷如果數(shù)組還有可以取出的元素,以防下標越界
if (temp_array.length>0) {
//在數(shù)組中產(chǎn)生一個隨機索引
var arrIndex = Math.floor(Math.random()*temp_array.length);
//將此隨機索引的對應的數(shù)組元素值復制出來
return_array[i] = temp_array[arrIndex];
//然后刪掉此索引的數(shù)組元素,這時候temp_array變?yōu)樾碌臄?shù)組
temp_array.splice(arrIndex, 1);
} else {
//數(shù)組中數(shù)據(jù)項取完后,退出循環(huán),比如數(shù)組本來只有10項,但要求取出20項.
break;
}
}
return return_array;
}
//測試
var my_array = new Array();
for (i = 0; i < 20; i++)
{
my_array[i] = "Num:"+i;
}
my_array = getArrayItems(my_array,5);
for (i = 0; i < my_array.length; i++)
{
alert(my_array[i]);
}
</script>
您可能感興趣的文章:
- 使用js Math.random()函數(shù)生成n到m間的隨機數(shù)字
- Javascript 生成指定范圍數(shù)值隨機數(shù)
- JS生成某個范圍的隨機數(shù)【四種情況詳解】
- javascript獲取不重復的隨機數(shù)的方法比較
- js生成隨機數(shù)之random函數(shù)隨機示例
- JavaScript 產(chǎn)生不重復的隨機數(shù)三種實現(xiàn)思路
- js實現(xiàn)簡單排列組合的方法
- JS實現(xiàn)的全排列組合算法示例
- JS實現(xiàn)的排列組合算法示例
- JS實現(xiàn)二維數(shù)組元素的排列組合運算簡單示例
- JavaScript隨機數(shù)的組合問題案例分析
相關文章
Javascript和HTML5利用canvas構建Web五子棋游戲實現(xiàn)算法
這只是一個簡單的JAVAscript和HTML5小程序,沒有實現(xiàn)人機對戰(zhàn),五子棋棋盤落子點對應的二維數(shù)組,具體的實現(xiàn)算法如下,感興趣的朋友可以參考下哈,希望對大家有所幫助2013-07-07原生Js Canvas去除視頻綠幕背景的方法實現(xiàn)
本文主要介紹了原生Js Canvas去除視頻綠幕背景的方法實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-09-09JS中使用new Option()實現(xiàn)時間聯(lián)動效果
這篇文章主要介紹了JS中使用new Option()實現(xiàn)時間聯(lián)動效果,需要的朋友可以參考下2018-12-127. Microsoft Online-Crash Control, version 6.0(微軟在線崩潰控件)
7. Microsoft Online-Crash Control, version 6.0(微軟在線崩潰控件)...2007-08-08