C++单链表的逆置、反转

代码如下:(内含注释,希望对大家有帮助)

#include <iostream>
using namespace std ;
class Node{
	public:
	int data ;
	Node *next ;
};
//创建链表(同时可以将tail为指针带出函数) 
Node * createNode(int n , Node **tail){
	Node *head = new Node ;
	Node *pre = head ;
	for(int i = 0 ; i < n ; i++){
		Node *p = new Node ;
		cin>>p->data ; 
		pre->next = p ;
		pre = p ; 
		p->next = NULL  ;  
	} 
	return head ;
}
//打印链表 
void display(Node *head){
	Node *p = head->next ; 
	while(p != NULL){
		cout<<p->data<<" " ;
		p = p->next ;
	}
}
//链表的逆置 
Node* reverse(Node *head ){
	//标记头结点 
	Node *flag = head ; 
	Node *first , *second ;
	first = flag->next ;
	flag->next = NULL ; 
	//画个图就很容易明白了 
	while(first != NULL){
		second = first->next ;
		//第一次循环时还可以顺便将最后结点的后继设置为空 
		first->next = flag->next ;
		flag->next = first ;
		first = second ;
	}
	return flag ; 
}
int main(){
	Node *tail ;
	Node *p = createNode(5 , &tail) ;
	display(p) ;
	cout<<"\n" ;
	display(reverse(p)) ; 
	return 0 ;
}

运行结果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值