题目:输入一个链表,反转链表后,输出新链表的表头。

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;
}
};

  

最新文章

  1. iOS UITableViewableViewCell自适应高度
  2. 最新IP地址数据库
  3. hbm.xml支持的类型
  4. sql中的触发器、视图、事务
  5. 【HDOJ】3560 Graph’s Cycle Component
  6. 锐浪应用小插曲,asp.net下的使用
  7. HDU 2255 奔小康赚大钱
  8. Struts2(四)——页面相关内容
  9. 在现有代码中通过async/await实现并行
  10. JavaWeb之Listener监听器
  11. JavScript--表单提交
  12. 如何使用EasyUI显示表格界面
  13. Steeltoe之Distributed Tracing篇
  14. Java 基础 在Java中需要使用内存的组件
  15. 多线程学习笔记九之ThreadLocal
  16. system的共享内存实例
  17. ie6遮罩层兼容 100%高度的实现
  18. C语言 · 判断回文
  19. kafka_zookeeper_配置文件配置
  20. ideal key

热门文章

  1. vite中使用img标签
  2. vue 使用mixin
  3. C. Tea Tasting
  4. hyper给linux扩容空间
  5. Win10在线升级Win11
  6. pkill 直接对进程对名字进行操作,可以同时杀死多个进程。
  7. Go--生成excel表格,读取excel表格数据
  8. python 删除大于超过一定时间文件
  9. Day22:数据库导入&分工&准备科研训练
  10. vue教程