码迷,mamicode.com
首页 > 其他好文 > 详细

链表逆序 和 寻找链表中间节点

时间:2016-05-08 10:25:32      阅读:184      评论:0      收藏:0      [点我收藏+]

标签:

已知链表的头节点为head,写一个函数把链表逆序。

void reserve(list_node* head){
     if(head == NULL)
       return 0;
     list_node* p = head;
     list_node* q = p->next;
     list_node* r = NULL;
     while(q){
        r = q->next;
        q->next = p;
        p = q;
        q = r;
   }
      head->next == NULL;
      head = p;
}

找出单链表的中间节点

list_node* findMiddleNode(list_node* head){
   if(head == NULL || head->next == NULL){
       return 0;
    }
    list_node* p = head;
    list_node* q = head; 
   while(q->next!=NULL&&q->next->next!=NULL){
    p = p->next;
    q = q ->next->next;
   }
    return p;
}

  

链表逆序 和 寻找链表中间节点

标签:

原文地址:http://www.cnblogs.com/zqlmmd/p/5469855.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!