新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
单链表的反转问题
创新互联公司专业为企业提供襄垣网站建设、襄垣做网站、襄垣网站设计、襄垣网站制作等企业网站建设、网页设计与制作、襄垣企业网站模板建站服务,十年襄垣做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
单链表反转问题经常会遇到。在此记录一下,以便查阅方便。
如果反转一个有头结点的使用下面的方法比较合适。
//反转单链表,此单链表带有头节点。 //思想:使用tmp临时指针保存头结点与链表的关系 typedef struct ListNode { int data; struct ListNode * next; }ListNode,*LinkList; void ReverseList(ListNode* Head) { ListNode *current,*tmp; current = Head->next; if(current != NULL)//反转后第一个节点的后继要为NULL { tmp = current; current = current->next; tmp->next = NULL; } while(current!=NULL) { tmp = current; current = current->next; tmp->next = Head->next; Head->next = tmp; } }
如果没有头结点,下面的反转比较合适
//如果没有头节点,下面的函数比较适合 //思想:使用pre和next两个指针来记录当前处理的节点的前一个节点和后一个节点的信息 ListNode * ReverseLinkList(ListNode * head) { ListNode * pre,*next; pre = NULL; next = NULL; while(head) { next = head->next; head->next = pre; pre = head; head = next; } return pre; }