算法導(dǎo)論練習(xí)2.3-2和2.3-3

Merge函數(shù)的實(shí)現(xiàn)

以下是c語言實(shí)現(xiàn)的源碼

merge函數(shù)是歸并排序的工具函數(shù),很重要。數(shù)組下標(biāo)的加加減減要小心。

void merge(int arr[], int p, int q, int r)
{
    int n1 = q - p + 1; //左數(shù)組的size 4
    int n2 = r - q;     //右數(shù)組的size 6
    int left[n1];
    int right[n2];
    //復(fù)制到新數(shù)組
    for (int i = 0; i < n1; i++)
    {
        left[i] = arr[i + p - 1];
    }
    for (int j = 0; j < n2; j++)
    {
        right[j] = arr[j + q];
    }

    int i = 0;
    int j = 0;
    int k = p - 1;
    while (i != n1 && j != n2)
    {
        if (left[i] < right[j])
        {
            arr[k] = left[i];
            i++;
        }
        else
        {
            arr[k] = right[j];
            j++;
        }
        k++;
    }
    if (i == n1)
    {
        while (j < n2)
        {
            arr[k] = right[j];
            j++;
            k++;
        }
    }
    else
    {
        while (i < n1)
        {
            arr[k] = left[i];
            i++;
            k++;
        }
    }
}

然后是數(shù)學(xué)歸納法證明題:

IMG_0034.JPG
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

  • 1 初級(jí)排序算法 排序算法關(guān)注的主要是重新排列數(shù)組元素,其中每個(gè)元素都有一個(gè)主鍵。排序算法是將所有元素主鍵按某種方...
    深度沉迷學(xué)習(xí)閱讀 1,435評(píng)論 0 1
  • 冒泡排序 冒泡排序相對(duì)來說是較為簡單的一種排序,它的思想就是在每一次循環(huán)中比較相鄰的兩個(gè)數(shù),通過交換的方式,將最小...
    陌上疏影涼閱讀 596評(píng)論 0 3
  • 2016.7.5-2016.10.15,坐標(biāo)上海。一直想寫寫自己在魔都呆了幾個(gè)月的切身感受,給那些準(zhǔn)備來上海...
    younger大大閱讀 1,435評(píng)論 13 4
  • 現(xiàn)金再投資比率>10% 公司靠自己日常營運(yùn)實(shí)力賺來的錢(營業(yè)活動(dòng)現(xiàn)金流量)扣除掉給股東現(xiàn)金股利之后,公司最后自己手...
    xieying466閱讀 352評(píng)論 0 0
  • 業(yè)余時(shí)間,靜下心,畫幾張小畫。 其實(shí),讀書時(shí)就喜歡畫畫。 工作后,忙忙碌碌,斷斷續(xù)續(xù),近幾年才重拾舊好。 謝謝觀賞。
    王者_(dá)52be閱讀 1,269評(píng)論 70 104