单链表的反转
如何把一个单链表进行反转?
方法1:将单链表储存为数组,然后按照数组的索引逆序进行反转。
方法2:使用3个指针遍历单链表,逐个链接点交替使用指针改变链表的指向进行反转。
方法3:从第3个节点到第N-1个节点,依次逐节点插入到第1个节点(head节点)之后,再将第N个节点指向head(成环),然后将此时head的下一个节点设为head,最后将原head指向NULL。
方法4: 递归(没搞懂~)
方法2:
- ActList* ReverseList2(ActList* head)
- {
- //ActList* temp=new ActList;
- if(NULL==head|| NULL==head->next) return head; //少于两个节点没有反转的必要。
- ActList* p;
- ActList* q;
- ActList* r;
- p = head;
- q = head->next;
- head->next = NULL; //旧的头指针是新的尾指针,next需要指向NULL
- while(q){
- r = q->next; //先保留下一个step要处理的指针
- q->next = p; //然后p q交替工作进行反向
- p = q;
- q = r;
- }
- head=p; // 最后q必然指向NULL,所以返回了p作为新的头指针
- return head;
- }
方法3:
- ActList* ReverseList3(ActList* head)
- {
- ActList* p;
- ActList* q;
- p=head->next;
- while(p->next!=NULL){
- q=p->next;
- p->next=q->next;
- q->next=head->next;
- head->next=q;
- }
- p->next=head;//相当于成环
- head=p->next->next;//新head变为原head的next
- p->next->next=NULL;//断掉环
- return head;
- }
详见: