C 单向链表就地逆转

1、问题描述

给定一个单链表L,设计函数Reverse将L就地逆转。即不需要申请新的节点,将第一个节点转换为最后一个结点,第二个节点转换为倒数第二个结点,以此类推。

2、思路分析

循环处理整个链表。将原链表的第一个结点取出,作为逆转后新链表的第一个结点(即新链表的链表头),同时原链表的第二个结点更新为原链表的链表头。之后不断取出原链表的链表头,插在新链表的链表头之前,即原链表的链表头不断“叛变到”新链表中充当新链表的链表头,从而达到就地逆转的目的。

3、代码分享及结果展示

PtrToNode Reverse(PtrToNode pOldHead)
{
	PtrToNode pNewHead = NULL;
	PtrToNode pTemp = NULL;
	while (pOldHead != NULL)
	{
		pTemp = pOldHead->nextPtr;//暂时存储原链表第二个结点地址
		pOldHead->nextPtr = pNewHead;//将原链表第一个结点的nextPtr指向新链表的链表头
		pNewHead = pOldHead;//更新新链表链表头
		pOldHead = pTemp;//更新原链表链表头
	}
	return pNewHead;//返回逆转后链表头
}

转载于:https://www.cnblogs.com/HL-space/p/10546598.html

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值