【剑指Offer】【链表】反转链表
2024-10-22 05:02:27
题目:输入一个链表,反转链表后,输出新链表的表头。
A:定义3个结点,pNode作移动指针,pRet作输出指针,pPrev作前驱指针
在pNode没有到达链尾之前,循环里创建pNext指针记录pNode的后继结点
如果pNode为空,代表已经到了链尾,输出结果
其他:pNode的next指向pPrev,pPrev指向pNode,pNode指向pNext
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
class Solution {
public:
ListNode* ReverseList(ListNode* pHead) {
if(pHead == nullptr)
{
return nullptr;
}
ListNode *pNode = pHead;
ListNode *pPrev = nullptr;
ListNode *pRet = nullptr; while(pNode != nullptr)
{
ListNode *pNext = pNode->next;
if(pNext == nullptr)
{
pRet = pNode;
}
pNode->next = pPrev; //精髓
pPrev = pNode;
pNode = pNext;
}
return pRet;
}
};
最新文章
- iOS UITableViewableViewCell自适应高度
- 最新IP地址数据库
- hbm.xml支持的类型
- sql中的触发器、视图、事务
- 【HDOJ】3560 Graph’s Cycle Component
- 锐浪应用小插曲,asp.net下的使用
- HDU 2255 奔小康赚大钱
- Struts2(四)——页面相关内容
- 在现有代码中通过async/await实现并行
- JavaWeb之Listener监听器
- JavScript--表单提交
- 如何使用EasyUI显示表格界面
- Steeltoe之Distributed Tracing篇
- Java 基础 在Java中需要使用内存的组件
- 多线程学习笔记九之ThreadLocal
- system的共享内存实例
- ie6遮罩层兼容 100%高度的实现
- C语言 · 判断回文
- kafka_zookeeper_配置文件配置
- ideal key