【學習點滴-資料結構-單鏈表】單鏈表的就地逆置

來源:互聯網
上載者:User
題目描述:給定一個單鏈表,對此單鏈表進行就地逆置“就地”:是指不需要開闢新的鏈資料表空間,而是在原鏈表的基礎上調整指標的走向
/* * 演算法功能:建立單鏈表,對單鏈表進行就地逆置。 * 演算法中的單鏈表是不帶頭結點的。  * 函數說明: * 1.TransLinklist(Linklist &L):遞迴地對單鏈表進行逆置 * 2.TranLinkNoneRecur(Linklist &L) :迴圈地對單鏈表的每個節點進行逆置 * @author:xiaoq-ohmygirl * @time :2012-06-20 **/#include <stdio.h>#include <malloc.h>#include <stdlib.h>#define MAXNODE 5typedef struct linkNode{    int data;    linkNode * next;}linkNode,*linkList;int createLinkList(linkList & L,int n){    L = (linkList)malloc(sizeof(linkNode));    if(!L){        return 0;    }    scanf("%d",&L->data);    L->next = NULL;    linkList p;    for(int i = n-1;i > 0;i--){         p = (linkList)malloc(sizeof(linkNode));         scanf("%d",&p->data);         p->next = L->next;         L->next = p;    }    return 1;}linkList reverseLinklist(linkList &L){   if( L == NULL || L->next == NULL){       return  L;   }   linkList node = reverseLinklist(L->next);   L->next->next = L;   L->next = NULL;   return node;}linkList reverseLinkNoneRecur(linkList L){     if(L == NULL){        return L;            }     linkList pre = NULL,cur = L,p = NULL;     while(cur->next != NULL){          p = cur->next;                     cur->next = pre;          pre = cur;          cur = p;              }     cur->next = pre;     return cur;}void visit(linkNode * node){    printf("%d->",node->data);}void getNewLine(){    printf("\n");}//不帶頭結點的單鏈表 void traverseLink(linkList L){    linkNode* cur = L;    getNewLine();    while(cur != NULL){        visit(cur);        cur = cur->next;    }    getNewLine();}main(){    linkList La = NULL,Lb = NULL,Lc = NULL;        createLinkList(La,MAXNODE);    printf("1:  ");    traverseLink(La);        Lb = reverseLinklist(La);    printf("2:  ");    traverseLink(Lb);        Lc = reverseLinkNoneRecur(Lb);    printf("3:  ");    traverseLink(Lc);    system("pause");    return 0;}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.