LeetCode 206——链表反转(JAVA)
题目:
反转一个单链表。
示例:
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL
进阶:
你可以迭代或递归地反转链表。你能否用两种方法解决这道题?
题解:
先上代码:
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution
{
public ListNode reverseList(ListNode head)
{
if(head==null||head.next==null)//链表为空或者只有一个元素
{
return head;
}
else
{
ListNode newHead=reverseList(head.next);//递归进行,通过这个语句之后,head节点之后的节点已经全部翻转完毕,这个时候,只需要把head节点放在新链表最后就好
head.next.next=head;//head节点应该放在head.next.next
head.next=null;//head已经是最后一个节点,所以head.next=null
return newHead;//返回新的头节点,作为递归的起点
}
}
}
以上为递归翻转链表的代码
递归终止条件:1、head为空。2、head.next为空
递归过程:我们令新的头节点为newHead,新的头节点newHead应该是head 翻转完之后的head.next。同时head也应该放在了head.next的后面,并令head.next=null。这样我们就把head放在了新链表的最后面(递归到最后面才实现把、这一步,下面我们画一个图表示一下这个递归的过程)。
算法分析:
时间复杂度,空间复杂度分析:涉及到递归,每递归一次的时间复杂度为O(1),因此整个递归时间复杂度为O(n),n为链表长度。对于空间复杂度,递归算法不涉及新空间的开辟,因此空间复杂度也是O(n),(这里对于空间复杂度的分析好像有问题......)
那么有没有非递归算法哪?有的!实际上,大多数的递归算法都是可以非递归实现的,只是稍微复杂了一点。
那么先上非递归算法代码,再分析这个算法吧!
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution
{
public ListNode reverseList(ListNode head)
{
ListNode newNode=new ListNode(-1);
ListNode node1,node2,node3;
newNode.next=head;
node1=newNode;
if(node1.next==null||node1.next.next==null)//和上面一样的原因
{
return head;
}
else
{
node2=node1.next;
node3=node2.next;
while(node3!=null)//以下代码是关键,实现了,每次将一个节点调到头节点位置,然后node2,node3指针后移。
{
node2.next=node3.next;
ListNode temp=node1.next;
node1.next=node3;
node3.next=temp;
node3=node2.next;
}
}
return newNode.next;
}
}
算法分析:
1、设置了一个虚拟的头节点newNode,以及三个指针,node1、node2、node3。
2、令newNode.next指向head.
3、如果newNode.next.next或者newNode.next==null直接返回原链表
4、否则,令node2指向node1.next,node3指向node2.next
5、如果node3不为空,执行一下部分:
node3指向的是待处理节点,node2指向待处理节点前一节点。
令node2.next指向node3.next
设立临时节点temp,存储node1.next
令node1.next指向node3,即将待处理节点放在头节点的位置,而令node3.next为temp
更新node3的值为node2.next
返回翻转之后的结果newNode.next
下面是手画的代码运行过程:将a b c 翻转为c b a
算法的分析:时间复杂度O(n),n为链表长度,空间复杂度,每循环一次,要开辟一个临时的节点空间,最后保留的只有一个,因此空间复杂度O(1)。
LeetCode 206——链表反转(JAVA)的更多相关文章
- LeetCode 206:反转链表 Reverse Linked List
反转一个单链表. Reverse a singly linked list. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3- ...
- 单链表反转java代码
据说单链表反转问题面试中经常问,而链表这个东西相对于数组的确稍微难想象,因此今天纪录一下单链表反转的代码. 1,先定义一个节点类. public class Node { int index; Nod ...
- 链表回文判断(基于链表反转)—Java实现
学习数据结构的时候遇到一个经典的回文链表问题 对于一个链表,请设计一个时间复杂度为O(n),额外空间复杂度为O(1)的算法,判断其是否为回文结构. 如果有链表反转的基础,实现链表回文判断就简单的多,如 ...
- Leetcode 206题 反转链表(Reverse Linked List)Java语言求解
题目描述: 反转一个单链表. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 迭代解 ...
- 【leetcode 206】 反转链表(简单)
链表 概念: 区别于数组,链表中的元素不是存储在内存中连续的一片区域,链表中的数据存储在每一个称之为「结点」复合区域里,在每一个结点除了存储数据以外,还保存了到下一个结点的指针(Pointer). 由 ...
- LeetCode - 206、反转链表
反转一个单链表. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL /** * 列表定 ...
- Java单链表反转 详细过程
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/guyuealian/article/details/51119499 Java单链表反转 Java实 ...
- Java实现 LeetCode 206 反转链表
206. 反转链表 反转一个单链表. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL ...
- LeetCode 206——反转链表
对单链表进行反转有迭代法和递归法两种. 1. 迭代法 迭代法从前往后遍历链表,定义三个指针分别指向相邻的三个结点,反转前两个结点,即让第二个结点指向第一个结点.然后依次往后移动指针,直到第二个结点为空 ...
随机推荐
- python正则表达式的用法
import re r1 = re.compile(r'(?im)(?P<name></html>)$') content = """ <H ...
- 浙江省赛C.Array in the Pocket(贪心+线段树)
题目链接: http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4102 题意: 给出一个长度为n的数组,重排它们,让相同位置的数 ...
- 2016多校7.14 Warmup 题解
先讲1007,是一个数位dp,询问一个区间内,各位数的和是一个素数的数字的个数.其实我并不会数位dp,这题直接套用了上次多校lyf队长的dp代码,改了点返回参数没想到直接AC了.代码如下: #incl ...
- Hadoop配置多个HDFS入口
为了验证存在不同的hdfs之间的hive的互操作(归根结底还是为了解决BUG) 需要在两个不同的hadoop集群的HDFS 能够在Hiveserver2上进行路由转发绕过一些坑. 就需要将某hdfs ...
- C#调用新浪微博API
WebRequest wq = WebRequest.Create(this.address); HttpWebRequest hq = wq as HttpWebRequest; string us ...
- 预处理、const、static、sizeof-为什么inline能很好地取代表达式形式的预定义
1:有如下几种原因: (1)inline定义的类的内联函数,函数的代码被放在符号表中,在使用时直接进行替换(像宏一样展开),没有了调用的开销,效率也很高. (2)类的内联函数也是一个真正的函数.编译器 ...
- 预处理、const、static与sizeof-static有什么作用(至少说出2个)
1:在C语言中,关键字static有3个明显的作用: (1)在函数体,一个被声明为静态的变量在这一函数被调用的过程中维持其值不变. (2)在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所 ...
- Leetcode题目94.二叉树的中序遍历(中等)
题目描述: 给定一个二叉树,返回它的中序遍历. 示例: 输入: [1,null,2,3] 1 \ 2 / 3 输出: [1,3,2] 进阶: 递归算法很简单,你可以通过迭代算法完成吗? 思路解析: 1 ...
- 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_3-5.PageHelper分页插件使用
笔记 5.PageHelper分页插件使用 简介:讲解开源组件,mybaits分页插件的使用 1.引入依赖 <!-- 分页插件依赖 --> ...
- Python-sympy科学计算与数据处理(求极限及其它功能)
极限 其它功能