反转链表 c++实现

🍉反转链表

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

🌼示例

反转链表
输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]

🍎解题思路

我们可以将原有链表的指针全部反向,然后输出的既为反转后的结果,例如1->2->3->4->5,转换后就变成5->4->3->2->1,因此我们需要创建三个指针,一个是记录当前指针的指向,一个是指向之前元素的,一个是指向之后元素的,这样就可以将链表进行反向。
使用链表解决此问题时需要注意的点是,在创建链表时,我选用的是尾插法,这样不会改变指针的指向,否则使用头插法指针则指向最后的一个元素,这样直接输出也就反转了,那就体现不了这个算法了。
注意当创建头结点的时,进行反转时需要跳过头结点。

🍒参考代码(c++)

#include<iostream>
using namespace std;
typedef struct ListNode{
	int val;
	struct ListNode *next;
}ListNode, *LinkList;
ListNode* reverseList(ListNode* head) {
    ListNode* pre = nullptr;
    ListNode* cur = head;
    while(cur){
        ListNode * next = cur -> next;
        cur -> next = pre;
        pre = cur;
        cur = next;
    }
    cout << count << endl;
    return  pre;
}
//尾插法 需要注意的是此创建是含有头节点的 
void CreateList_W(LinkList &L,int n){
	ListNode *r;
	L=new ListNode;
	L->next = NULL;
	r = L;
	for(int i = 0; i < n; i++){
		ListNode *p = new ListNode;
		cin>>p->val;
		r->next = p;
		p->next=NULL;
		r=p;
	}

} 
void Print(ListNode* L){
	ListNode *p;
	p = L;
	while(p){
		cout << p -> val << " ";
		p = p -> next;  
	}
}
int main(){
	LinkList L;
	int n;
	cin >> n;
	CreateList_W(L,n);
	Print(reverseList(L -> next));
} 

题目来源 leetcode

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我是玄兔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值