數(shù)組快速排序/去重

數(shù)組排序
先來幾個高級算法:
從大到小排序:

var arr=[5,2,9,11,6,7,12];
arr.sort(function (n1,n2){
    return n2-n1;
});
alert(arr);

從小到大排序:

var arr=[5,2,9,11,6,7,12];
arr.sort(function (n1,n2){
    return n1-n2;
});
alert(arr);

隨機排序:

var arr=[5,2,9,11,6,7,12];
arr.sort(function (){
    return Math.random()-0.5;
});
alert(arr);

手寫數(shù)組排序:
方法一:
1.封裝函數(shù)遂蛀,找到iMinIndex罪治;
2.循環(huán)數(shù)組娜遵,把最小的放前放蜕衡;

function findIminIndex(arr,start){
            var iMin=arr[start];
            var iMinIndex=start;
            for(var i=start+1;i<arr.length;i++){
                if(arr[i]<iMin){
                    iMin=arr[i];
                    iMinIndex=i;
                }
            }
            return iMinIndex;
        }
        var arr=[34,12,7,5,6,135,99];
        for(var i=0;i<arr.length;i++){
            var n=findIminIndex(arr,i);
            //arr[n] arr[i]
            var temp;
            temp=arr[n];
            arr[n]=arr[i];
            arr[i]=temp;
        }
        alert(arr);

手寫數(shù)組去重
方法一:
1.構建新數(shù)組存放;
2.循環(huán)原數(shù)組设拟,并將沒有重復的push到新數(shù)組衷咽;

var arr=[11,22,2,2,3,4,55,5,4,4,3];
        function findInArr(item,arr){
            for(var i=0;i<arr.length;i++){
                if(arr[i]==item)return true;
            }
            return false;
        }
        var arr2=[];
        for(var i=0;i<arr.length;i++){
            if(!findInArr(arr[i],arr2)){
                arr2.push(arr[i]);
            }
        }
        //alert(arr2);
        document.write(arr2)

方法二:
1.根據(jù)json的鍵值不相同原則,將可以作為鍵值的push到一個新的數(shù)組中蒜绽;

var arr=[11,22,2,2,3,4,55,5,4,4,3];
        var json={};
        for(var i=0;i<arr.length;i++){
            json[arr[i]]='zzzzzz';
        }
        //console.log(json);
        var arr2=[];
        for(var name in json){
            arr2.push(name);
        }
        //alert(arr2);
        document.write(arr2);

方法三:
1.原數(shù)組排序;
2.比較原數(shù)組相鄰位置是否相等桶现;
3.若相當躲雅,splice該數(shù),并注意將i--骡和;

 var arr=[11,22,2,2,3,4,55,5,4,4,3];
        arr.sort();
        //alert(arr);
        for(var i=0;i<arr.length;i++){
            if(arr[i]==arr[i+1]){
                arr.splice(i,1);
                i--;
            }
        }
        alert(arr);
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末相赁,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子慰于,更是在濱河造成了極大的恐慌钮科,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件婆赠,死亡現(xiàn)場離奇詭異绵脯,居然都是意外死亡,警方通過查閱死者的電腦和手機休里,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進店門蛆挫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人妙黍,你說我怎么就攤上這事悴侵。” “怎么了拭嫁?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵可免,是天一觀的道長。 經(jīng)常有香客問我做粤,道長浇借,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任驮宴,我火速辦了婚禮逮刨,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己修己,他們只是感情好恢总,可當我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著睬愤,像睡著了一般片仿。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上尤辱,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天砂豌,我揣著相機與錄音,去河邊找鬼光督。 笑死阳距,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的结借。 我是一名探鬼主播筐摘,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼船老!你這毒婦竟也來了咖熟?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤柳畔,失蹤者是張志新(化名)和其女友劉穎馍管,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體薪韩,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡确沸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了俘陷。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片张惹。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖岭洲,靈堂內(nèi)的尸體忽然破棺而出宛逗,到底是詐尸還是另有隱情,我是刑警寧澤盾剩,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布雷激,位于F島的核電站,受9級特大地震影響告私,放射性物質發(fā)生泄漏屎暇。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一驻粟、第九天 我趴在偏房一處隱蔽的房頂上張望根悼。 院中可真熱鬧凶异,春花似錦、人聲如沸挤巡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽矿卑。三九已至喉恋,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間母廷,已是汗流浹背轻黑。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留琴昆,地道東北人氓鄙。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像业舍,于是被迫代替她去往敵國和親玖详。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,834評論 2 345

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