单链表逆置

 
单链表逆置
 
单链表逆置在面试中经常见到,于是自己随变写了一个与大家一起学习交流,有什么意见或建议欢迎提出,大家共同进步啊:-)
 
#include <stdio.h>
#include <stdlib.h>
#define ITEM_NUM 10
typedef struct tagNode {
    int e;
    struct tagNode *next;
}Node;
 
Node * LinkList_create();
void  LinkList_destroy(Node* head);
void  LinkList_print(Node* head);
Node * LinkList_reverse(Node* head);
 
int main(int argc,char* agrv[])
{
    Node* head = LinkList_create();
    Node* head_reversed;
 
    printf("The link list data is:/n");
 
    LinkList_print(head);
 
    head_reversed = LinkList_reverse(head);
 
    printf("After reversed,the link list data is:/n");
 
    LinkList_print(head_reversed);
 
    system("Pause");
 
}
 
Node * LinkList_create()
{
    Node* nodes = (Node*)calloc(ITEM_NUM,sizeof(Node));
 
    int i;
 
    printf("Create link list.../n");
    for(i=0;i<ITEM_NUM;i++)
    {
        nodes[i].e = (i+1)*3;
 
        if(i< ITEM_NUM-1)
            nodes[i].next = &nodes[i+1];
        else
            nodes[i].next = NULL;
    }
 
    return nodes;  
}
 
void LinkList_destroy(Node* head)
{
    printf("Destroy the link list.../n");
    if(head) free(head);
}
 
void LinkList_print(Node* head)
{
    if(head==NULL) return;
 
    while(head)
    {
        printf("%d/n",head->e);
        head = head->next;
    }
}
 
Node * LinkList_reverse(Node* head)
{
    Node *preNode,*curNode,*nextNode;
 
    if(head==NULL) return NULL;// 空链表
 
    if(head->next == NULL) return head;// 仅一个元素
 
    curNode = head;preNode=NULL;// 初始化
 
    while(curNode)
    {
        nextNode = curNode->next;// 先记录下一个结点
        curNode->next = preNode;// 改变链表方向(逆置)
        preNode = curNode;// 将当前结点作为下一次循环的前一个结点
        curNode = nextNode;// 向后推移一个结点
    }
 
    return preNode;// 当遍历完链表后 curNode 应该为空,此时 preNode 就是逆置后链表头 (head)
 
}
 
运行结果:
Create link list...
The link list data is:
3
6
9
12
15
18
21
24
27
30
After reversed,the link list data is:
30
27
24
21
18
15
12
9
6
3
Destroy the link list...

你可能感兴趣的:(单链表逆置)