巧用對(duì)象,生成不重復(fù)隨機(jī)數(shù)

有時(shí)候我們需要在一定范圍內(nèi)生成一組不重復(fù)的隨機(jī)數(shù)組辙培,我們可能會(huì)這樣做:

//需求:在一個(gè)已知的數(shù)組中,隨機(jī)選取一部分組成新的數(shù)據(jù)邢锯,要求數(shù)組元素不重復(fù)出現(xiàn):
    //常規(guī)實(shí)現(xiàn)
    var arr = [3,5,30,20,21,50,80,6,8,10,15]
    //去重一下,不去重扬蕊,可能造成死循環(huán)
    arr = arr.filter(function(element,index,self){
        return self.indexOf(element) === index;
    });
    var getArr = function (len) {
        var tempArr = []
        var mathIndex
        var arrLen = arr.length
        var arrItem
        var falg
        if(len > arrLen){
            console.log('無(wú)法獲取指定長(zhǎng)度的數(shù)組!')
            return
        }
        while (tempArr.length < len){
            falg = false
            //向下取整丹擎,得到0-(arrLen - 1)的整數(shù)
            mathIndex = Math.floor(Math.random() * arrLen)
            arrItem = arr[mathIndex]
            //判斷是否存在尾抑,存在即重新生成歇父,不存在則push
            for(var i = 0 ; i < tempArr.length ; i++){
                if(tempArr[i] === arrItem){
                    falg = true
                    break;
                }
            }
            //不存在
            if(!falg){
                tempArr.push(arrItem)
            }
        }
        return tempArr
    }
    getArr(5)
    getArr(6)
    getArr(11)

運(yùn)行截圖:


運(yùn)行截圖

可以看到,這樣實(shí)現(xiàn)的方式篇幅比較長(zhǎng)再愈,中間主要是由于要判斷是否有重復(fù)數(shù)組做了大量處理榜苫,我們換一個(gè)種方式來(lái)實(shí)現(xiàn)。

var arr = [3,5,30,20,21,50,80,6,8,10,15]
    //去重一下,不去重翎冲,可能造成死循環(huán)
    arr = arr.filter(function(element,index,self){
        return self.indexOf(element) === index;
    });
// 對(duì)象替換數(shù)組的方式實(shí)現(xiàn):
    var getMyArr = function (len) {
        var tempArr = []
        var mathIndex
        var arrLen = arr.length
        var arrItem
        var arrIndexMap = {}
        if(len > arrLen){
            console.log('無(wú)法獲取指定長(zhǎng)度的數(shù)組垂睬!')
            return
        }
        while (tempArr.length < len){
            //向下取整,得到0-(arrLen - 1)的整數(shù)
            mathIndex = Math.floor(Math.random() * arrLen)
            arrItem = arr[mathIndex]
            //判斷是否重復(fù)
            if(!arrIndexMap[mathIndex]){
                //不存在抗悍,push驹饺,并保存index
                tempArr.push(arrItem)
            //將索引存在對(duì)象里面,做判斷用
                arrIndexMap[mathIndex] = true
            }
        }
        console.log(tempArr)
        return tempArr
    }
    getMyArr(5)
    getMyArr(6)
    getMyArr(11)

可以看到上面用對(duì)象實(shí)現(xiàn)的時(shí)候缴渊,主要區(qū)別是在判斷生成的隨機(jī)數(shù)是否重復(fù)的部分赏壹。程序?qū)⑸傻碾S機(jī)數(shù)用對(duì)象的方式保存了起來(lái),然后只需要到對(duì)象里面取值衔沼,看是否取到值即可蝌借,避免了去原素組里面遍歷。這樣不僅簡(jiǎn)化了實(shí)現(xiàn)過(guò)程指蚁,還提高了代碼性能菩佑。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市凝化,隨后出現(xiàn)的幾起案子稍坯,更是在濱河造成了極大的恐慌,老刑警劉巖缘圈,帶你破解...
    沈念sama閱讀 219,110評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異袜蚕,居然都是意外死亡糟把,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門牲剃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)遣疯,“玉大人,你說(shuō)我怎么就攤上這事凿傅〔” “怎么了?”我有些...
    開封第一講書人閱讀 165,474評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵聪舒,是天一觀的道長(zhǎng)辨液。 經(jīng)常有香客問(wèn)我,道長(zhǎng)箱残,這世上最難降的妖魔是什么滔迈? 我笑而不...
    開封第一講書人閱讀 58,881評(píng)論 1 295
  • 正文 為了忘掉前任止吁,我火速辦了婚禮,結(jié)果婚禮上燎悍,老公的妹妹穿的比我還像新娘敬惦。我一直安慰自己,他們只是感情好谈山,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,902評(píng)論 6 392
  • 文/花漫 我一把揭開白布俄删。 她就那樣靜靜地躺著,像睡著了一般奏路。 火紅的嫁衣襯著肌膚如雪畴椰。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,698評(píng)論 1 305
  • 那天思劳,我揣著相機(jī)與錄音迅矛,去河邊找鬼。 笑死潜叛,一個(gè)胖子當(dāng)著我的面吹牛秽褒,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播威兜,決...
    沈念sama閱讀 40,418評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼销斟,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了椒舵?” 一聲冷哼從身側(cè)響起蚂踊,我...
    開封第一講書人閱讀 39,332評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎笔宿,沒想到半個(gè)月后犁钟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,796評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡泼橘,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,968評(píng)論 3 337
  • 正文 我和宋清朗相戀三年涝动,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片炬灭。...
    茶點(diǎn)故事閱讀 40,110評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡醋粟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出重归,到底是詐尸還是另有隱情米愿,我是刑警寧澤,帶...
    沈念sama閱讀 35,792評(píng)論 5 346
  • 正文 年R本政府宣布鼻吮,位于F島的核電站育苟,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏椎木。R本人自食惡果不足惜宙搬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,455評(píng)論 3 331
  • 文/蒙蒙 一笨腥、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧勇垛,春花似錦脖母、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,003評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至讼积,卻和暖如春肥照,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背勤众。 一陣腳步聲響...
    開封第一講書人閱讀 33,130評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工舆绎, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人们颜。 一個(gè)月前我還...
    沈念sama閱讀 48,348評(píng)論 3 373
  • 正文 我出身青樓吕朵,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親窥突。 傳聞我的和親對(duì)象是個(gè)殘疾皇子努溃,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,047評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,103評(píng)論 1 32
  • 國(guó)家電網(wǎng)公司企業(yè)標(biāo)準(zhǔn)(Q/GDW)- 面向?qū)ο蟮挠秒娦畔?shù)據(jù)交換協(xié)議 - 報(bào)批稿:20170802 前言: 排版 ...
    庭說(shuō)閱讀 10,988評(píng)論 6 13
  • 方法1 (數(shù)據(jù)類型)(最小值+Math.random()*(最大值-最小值+1)) 例: (int)(1+Math...
    GB_speak閱讀 41,001評(píng)論 2 6
  • 2017年,9.10日志 今天是一個(gè)很特別的日子阻问,是第33個(gè)教師節(jié)梧税!是我們TA legacy鄂州樂(lè)善助學(xué)主題"孩子...
    藍(lán)朵格格閱讀 326評(píng)論 0 3
  • 心心念念的激情,徜徉在黎明晨曦長(zhǎng)上翅膀的心隨著白云称近,來(lái)到你的懷抱滾燙炙熱的煎熬第队,沸騰了渴盼的遐想旖旎在湛藍(lán)天空,起...
    淺淺是水閱讀 1,077評(píng)論 63 75