鏈表每k個(gè)元素翻轉(zhuǎn)

原始鏈表:0 -> 1 -> 2 -> 3 -> 4 -> 5 -> 6 -> 7 -> 8 -> 9 -> NULL
k = 2:1 -> 0 -> 3 -> 2 -> 5 -> 4 -> 7 -> 6 -> 9 -> 8 -> NULL
k = 3:2 -> 1 -> 0 -> 5 -> 4 -> 3 -> 8 -> 7 -> 6 -> 9 -> NULL

#include <iostream>
#include <stdlib.h>

using namespace std;

struct link_node {
    int i;
    link_node *next;
};

//標(biāo)準(zhǔn)鏈表翻轉(zhuǎn)
link_node * reverse(link_node * head) {
    if (head == NULL) {
        return NULL;
    }

    link_node *p = head->next;
    head->next = NULL;
    while (p != NULL) {
            link_node *q = p->next;
            p->next = head;
            head = p;
            p = q;
    }

    return head;
}

/* 更簡(jiǎn)潔
link_node * reverse(LinkNode *head)
{
        link_node *pre = NULL;

        while (head != NULL)
        {
                link_node *p = head->next;
                head->next = pre;
                pre = head;
                head = p;
        }

        return pre;
}
*/

//鏈表每k個(gè)元素翻轉(zhuǎn)
link_node *reverse_k(link_node * head, int k) {
    link_node *p = head;
    link_node *last_tail = NULL; 
    link_node *new_head = NULL;

    while (p != NULL) {
        //截取鏈表的k個(gè)元素
        link_node *q = p;
        for (int i=0; i<k-1; ++i) {
            if (q == NULL) break;
            q = q->next;
        }

        //如果沒(méi)有到鏈表尾部,用tmp記錄鏈表的剩余部分
        link_node *tmp = NULL;
        if (q != NULL) {
            tmp = q->next;
            q->next = NULL;  //將k個(gè)元素的鏈表末尾指向NULL曹洽,形成一個(gè)新鏈表琳彩,以便進(jìn)行標(biāo)準(zhǔn)鏈表翻轉(zhuǎn)
        }

        link_node *h = reverse(p);  //翻轉(zhuǎn)后囤屹,h為新鏈表頭隧枫,p為新鏈表尾

        if (p == head) new_head = h;  //第一批k個(gè)元素翻轉(zhuǎn)后的頭是最終鏈表的頭
        else last_tail->next = h;           //其余每k元素鏈表的頭接到上批k元素鏈表的尾

        last_tail = p;  //記錄上批k元素鏈表的尾
        p = tmp;        //移到鏈表剩余部分開(kāi)始處理下批k
    }

    return new_head;
}

int main(int argc, char *argv[]) {
    if (argc < 2) {
        cerr << "Usage: " << argv[0] << " k" << endl;
        return -1;
    }
    link_node *head = new(link_node);
    head->i = 0;
    link_node *p = head;
    for (int i=1; i<10; ++i) {
        link_node *tmp = new(link_node);
        tmp->i = i;
        p->next = tmp;
        p = p->next;
    }
    p->next = NULL;

    cout << "src link" << endl;
    p = head;
    while (p!= NULL) {
        cout << p->i << " -> ";
        p = p->next;
    }
    cout << "NULL" << endl;

    cout << "new link" << endl;
    link_node *head2 = reverse_k(head, atoi(argv[1]));
    p = head2;
    while (p!= NULL) {
        cout << p->i << " -> ";
        p = p->next;
    }
    cout << "NULL" << endl;

    return 0;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市菩帝,隨后出現(xiàn)的幾起案子过蹂,更是在濱河造成了極大的恐慌,老刑警劉巖硬鞍,帶你破解...
    沈念sama閱讀 212,542評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件慧瘤,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡固该,警方通過(guò)查閱死者的電腦和手機(jī)锅减,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)伐坏,“玉大人怔匣,你說(shuō)我怎么就攤上這事¤氤粒” “怎么了每瞒?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,021評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)纯露。 經(jīng)常有香客問(wèn)我剿骨,道長(zhǎng),這世上最難降的妖魔是什么埠褪? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,682評(píng)論 1 284
  • 正文 為了忘掉前任懦砂,我火速辦了婚禮,結(jié)果婚禮上组橄,老公的妹妹穿的比我還像新娘荞膘。我一直安慰自己,他們只是感情好玉工,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,792評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布羽资。 她就那樣靜靜地躺著,像睡著了一般遵班。 火紅的嫁衣襯著肌膚如雪屠升。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,985評(píng)論 1 291
  • 那天狭郑,我揣著相機(jī)與錄音腹暖,去河邊找鬼。 笑死翰萨,一個(gè)胖子當(dāng)著我的面吹牛脏答,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 39,107評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼殖告,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼阿蝶!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起黄绩,我...
    開(kāi)封第一講書(shū)人閱讀 37,845評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤羡洁,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后爽丹,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體筑煮,經(jīng)...
    沈念sama閱讀 44,299評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,612評(píng)論 2 327
  • 正文 我和宋清朗相戀三年粤蝎,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了咆瘟。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,747評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡诽里,死狀恐怖袒餐,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情谤狡,我是刑警寧澤灸眼,帶...
    沈念sama閱讀 34,441評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站墓懂,受9級(jí)特大地震影響焰宣,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜捕仔,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,072評(píng)論 3 317
  • 文/蒙蒙 一匕积、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧榜跌,春花似錦闪唆、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,828評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至础浮,卻和暖如春帆调,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背豆同。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,069評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工番刊, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人影锈。 一個(gè)月前我還...
    沈念sama閱讀 46,545評(píng)論 2 362
  • 正文 我出身青樓芹务,卻偏偏與公主長(zhǎng)得像蝉绷,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子锄禽,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,658評(píng)論 2 350

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