zoukankan      html  css  js  c++  java
  • 《剑指offer》面试题16 反转链表 Java版

    (输入链表的头节点,反转链表)

    书中方法:对于一个链表,我们只能从头往后遍历,如果要反转,我们需要更改当前节点的next域指向前一个节点,此时链表断开,为了能继续修改下一个节点的next域,我们还要维护下一个节点。

    	public ListNode reverse(ListNode first){
    		if(first == null)return first;
    		ListNode last = null;
    		ListNode now = first;
    		ListNode next = first.next;
    		while(now != null){
    			now.next = last;
    			
    			last = now; 
    			now = next;
    			if(now != null){
    				next = now.next;
    			}
    		}
    		return last;
    	}
    

    方法二:书后面还提到了递归的方法。自己写的逻辑比较不清楚,在网上找了一个版本。这个方法的思路是:递归返回的是当前节点右侧已经反转好的链表的头节点,对于当前的节点,将它连接到已经reverse好的链表的末尾,返回值是添加了该节点的新链表头。先递归后处理,最后的返回值是反转后的节点,每次递归返回的是添加了当前节点的反转后的链表。注意递归出口的处理。

    	public ListNode reverse2(ListNode first){
    		if(first == null || first.next == null)return first;
    		
    		ListNode newHead = reverse2(first.next);
    		first.next.next = first;
    		first.next = null;
    		
    		return newHead;
    		
    	}
    
  • 相关阅读:
    软件工程(2019)第二次作业
    软件工程(2019)第一次作业
    【Java基础】字面量相加的类型转换
    测试之合作篇
    功能测试之难以重现的bug
    功能测试知识之Web输入框验证
    如何编写有效的测试用例?
    Java:switch语句例子
    【转】成功的概念
    Java里的if else嵌套语句例子
  • 原文地址:https://www.cnblogs.com/czjk/p/11611783.html
Copyright © 2011-2022 走看看