博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode206 反转链表
阅读量:4143 次
发布时间:2019-05-25

本文共 520 字,大约阅读时间需要 1 分钟。

反转链表

题目

反转一个单链表。

示例:

输入: 1->2->3->4->5->NULL

输出: 5->4->3->2->1->NULL

思路:

使用三个指针,分别标记上一次反转后的表头,这一次需要反转的节点和下一次需要反转的节点

过程中相当于将一个链表拆成了两个
以示例来说就是
第一次反转后成为 1 和 2345
第二次反转后成为 21 和 345
第三次反转后成为 321 和 45
等等

代码如下:

struct ListNode* reverseList(struct ListNode* head){    struct ListNode *next;    struct ListNode *curr = head;    struct ListNode *pre = NULL;    if(head == NULL)         return head;    while(curr) {        next = curr -> next;        curr -> next = pre;        pre = curr;        curr = next;    }    return pre;}

转载地址:http://nwkti.baihongyu.com/

你可能感兴趣的文章
Linux 查看端口使用情况
查看>>
文件隐藏
查看>>
两个linux内核rootkit--之二:adore-ng
查看>>
两个linux内核rootkit--之一:enyelkm
查看>>
关于linux栈的一个深层次的问题
查看>>
rootkit related
查看>>
配置文件的重要性------轻化操作
查看>>
又是缓存惹的祸!!!
查看>>
为什么要实现程序指令和程序数据的分离?
查看>>
我对C++ string和length方法的一个长期误解------从protobuf序列化说起(没处理好会引起数据丢失、反序列化失败哦!)
查看>>
一起来看看protobuf中容易引起bug的一个细节
查看>>
无protobuf协议情况下的反序列化------貌似无解, 其实有解!
查看>>
make -n(仅列出命令, 但不会执行)用于调试makefile
查看>>
makefile中“-“符号的使用
查看>>
go语言如何从终端逐行读取数据?------用bufio包
查看>>
go的值类型和引用类型------重要的概念
查看>>
求二叉树中结点的最大值(所有结点的值都是正整数)
查看>>
用go的flag包来解析命令行参数
查看>>
来玩下go的http get
查看>>
感受一下go协程goroutine------协程在手,说go就go
查看>>