ListNode* ReverseList(ListNode* head) {
ListNode* pnode = head; //记住只有pnode初始化不为空
ListNode* pReversed = NULL; //若链表空则直接返回pReversed
ListNode* prev = NULL; //因为第一个结点反转后需要指向空
while(pnode != NULL)
{
ListNode* pnext = pnode->next; //保存指向下一个结点的指针,防止链表断裂
if(pnext == NULL) //到了链表结尾,pReversed指向最后一个结点
pReversed = pnode;
pnode->next = prev; //记住这个顺序,画图可以帮助回忆
prev = pnode;
pnode = pnext;
}
return pReversed;
}
链表反转
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 链表反转 方法一:迭代法保存当前节点的下一个节点,防止掉链;当前节点的next指针指向前一个节点;向后移动节点。 ...
- // 折半查找 int search(int *a, int n, int key) { int min, m...