Sort Algorithm—MIT算法導(dǎo)論

插入排序

image.png
/**
 * Created by 編程只服JAVA on 2017.07.13.
 */
var arr = [1,43,23,56,12];

function inSertSort(Array)
{
    for(var i = 1; i < Array.length; ++i)
    {
        //插入的起手位置
        var key = arr[i];
        //已排好序的部分Array[0, j]
        var j = i - 1;

        //如果插入的起手位置 < 前面排好序的部分
        while (j > -1 && Array[j] > key)
        {
            Array[j + 1] = Array[j];
            --j;
        }

        //找到合適的插入位置雹姊,因?yàn)閖已經(jīng)跑到了前一個(gè)位置枪蘑,因此需要j + 1
        Array[j + 1] = key;
    }
}

inSertSort(arr);
console.info(arr);

冒泡排序

image.png
/**
 * Created by 編程只服JAVA on 2017.07.13.
 */
var arr = [1,43,23,56,12,12];

function bubbleSort(Array)
{
    //for Array[0, high - 1]
    for(var i = 0; i < Array.length - 1; ++i)
    {

        //優(yōu)化
        var flag = true;
        //for Array[high, i + 1] down to, 因?yàn)橄旅鍭rray[j] < Array[j - 1],所以j >= i + 1;
        //將小的元素向前冒
        for(var j = Array.length - 1; j >= i + 1; --j)
        {
            if (Array[j] < Array[j - 1])
            {
                var temp = Array[j];
                Array[j] = Array[j - 1];
                Array[j - 1] = temp;
                flag = false;
            }
        }

        if (flag) break;
    }
}

bubbleSort(arr);
console.info(arr);

選擇排序

/**
 * Created by 編程只服JAVA on 2017.07.13.
 */
var arr = [1,43,23,56,12,12];

function selectSort(Array)
{
    // 臨時(shí)變量朋截,用于交換
    var temp = 0;
    var minIndex = 0;

    // 要注意一點(diǎn)迁匠,當(dāng)要排序 N 個(gè)數(shù)海雪,已經(jīng)經(jīng)過(guò) N-1 次遍歷后曹傀,已經(jīng)是有序數(shù)列
    for(var i = 0; i < Array.length - 1; ++i)
    {
        // 用來(lái)保存最小值得索引
        minIndex = i;

        // 尋找第i個(gè)小的數(shù)值
        for(var j = i + 1; j < Array.length; ++j)
        {
            if (Array[j] < Array[minIndex])
            {
                minIndex = j;
            }
        }

        //可以加一個(gè)判斷minIndex != i,或許可以提升一點(diǎn)效率周荐,不加也可以
        // 將找到的第i個(gè)小的數(shù)值放在第i個(gè)位置上
        if (minIndex != i)
        {
            temp = Array[minIndex];
            Array[minIndex] = Array[i];
            Array[i] = temp;
        }
    }
}

selectSort(arr);
console.info(arr);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市僵娃,隨后出現(xiàn)的幾起案子概作,更是在濱河造成了極大的恐慌,老刑警劉巖默怨,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件讯榕,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡匙睹,警方通過(guò)查閱死者的電腦和手機(jī)愚屁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)痕檬,“玉大人霎槐,你說(shuō)我怎么就攤上這事∶蚊眨” “怎么了丘跌?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)唁桩。 經(jīng)常有香客問(wèn)我碍岔,道長(zhǎng),這世上最難降的妖魔是什么朵夏? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮榆纽,結(jié)果婚禮上仰猖,老公的妹妹穿的比我還像新娘。我一直安慰自己奈籽,他們只是感情好饥侵,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著衣屏,像睡著了一般躏升。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上狼忱,一...
    開(kāi)封第一講書(shū)人閱讀 51,573評(píng)論 1 305
  • 那天膨疏,我揣著相機(jī)與錄音,去河邊找鬼钻弄。 笑死佃却,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的窘俺。 我是一名探鬼主播饲帅,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了灶泵?” 一聲冷哼從身側(cè)響起育八,我...
    開(kāi)封第一講書(shū)人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎赦邻,沒(méi)想到半個(gè)月后髓棋,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡深纲,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年仲锄,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片湃鹊。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡儒喊,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出币呵,到底是詐尸還是另有隱情怀愧,我是刑警寧澤,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布余赢,位于F島的核電站芯义,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏妻柒。R本人自食惡果不足惜扛拨,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望举塔。 院中可真熱鬧绑警,春花似錦、人聲如沸央渣。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)芽丹。三九已至北启,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間拔第,已是汗流浹背咕村。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蚊俺,地道東北人培廓。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像春叫,于是被迫代替她去往敵國(guó)和親肩钠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子泣港,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

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

  • 一、 單項(xiàng)選擇題(共71題) 對(duì)n個(gè)元素的序列進(jìn)行冒泡排序時(shí)价匠,最少的比較次數(shù)是( )当纱。A. n ...
    貝影閱讀 9,072評(píng)論 0 10
  • 總結(jié)一下常見(jiàn)的排序算法。 排序分內(nèi)排序和外排序踩窖。內(nèi)排序:指在排序期間數(shù)據(jù)對(duì)象全部存放在內(nèi)存的排序坡氯。外排序:指在排序...
    jiangliang閱讀 1,346評(píng)論 0 1
  • 作者:大海里的太陽(yáng)原文地址:http://www.cnblogs.com/wxisme/ 前言 查找和排序算法是算...
    IT程序獅閱讀 2,500評(píng)論 0 63
  • Ba la la la ~ 讀者朋友們,你們好啊洋腮,又到了冷鋒時(shí)間箫柳,話不多說(shuō),發(fā)車(chē)啥供! 1.冒泡排序(Bub...
    王飽飽閱讀 1,797評(píng)論 0 7
  • 留不住你的是夢(mèng)想 當(dāng)你一往無(wú)前 不再回望 可是心還在牽掛 家呵 業(yè)呵 兩難全 身在哪里 心思何方 只有活好當(dāng)下 未...
    vonlyu閱讀 112評(píng)論 0 0