剑指offer15题
class ListNode { int val; ListNode next = null; ListNode(int val) { this.val = val; } } /** * 输入一个链表,反转链表后,输出新链表的表头。 * 注意:编程时,首先判断非法条件 * 思路: * 题目考的是递归 * 1、记住下一个要处理的节点:next指针指向curr的next * 2、翻转指针:curr的next指向pre * 3、pre,curr一起往下一个节点移动 * 4、重复 */ public class Solution15 { public ListNode ReverseList(ListNode head) { //1、首先处理非法条件 if (head == null||head.next == null){ return head; } ListNode preNode = head; ListNode currNode = head.next; //注意,如果不写会造成死循环 preNode.next = null; ListNode nextNode; while (null != currNode){ nextNode = currNode.next; currNode.next = preNode; preNode = currNode; currNode = nextNode; } return preNode; } }
Linux等环境软件安装