• 单链表逆序


    https://blog.csdn.net/autumn20080101/article/details/7607148

    package com.jd.etms.vrs.lean.link;
    
    /**
     * Created by zhangwenjun10 on 2018/11/26.
     */
    public class TestLink {
        public static void main(String args[]) {
    
            LinkNode headNode = creatSingleLink();
            printSingleLink(headNode);
            LinkNode temNode = reverseSingleLink(headNode);
            System.out.println();
            printSingleLink(temNode);
    
            LinkNode reverseNode = reverseLink(temNode);
            System.out.println();
            printSingleLink(reverseNode);
    
        }
    
        public static LinkNode creatSingleLink() {
    
            LinkNode headNode = new LinkNode(0);
            headNode.next = new LinkNode(1);
            headNode.next.next = new LinkNode(2);
            headNode.next.next.next = new LinkNode(3);
            headNode.next.next.next.next = new LinkNode(4);
            headNode.next.next.next.next.next = new LinkNode(5);
    
            return headNode;
        }
    
        public static void printSingleLink(LinkNode headNode) {
            if (headNode != null) {
                System.out.print("" + headNode.value);
            }
            if (null != headNode.next) {
                printSingleLink(headNode.next);
            }
        }
    
        /*单链表逆序*/
        public static LinkNode reverseSingleLink(LinkNode headNode) {
            if (null == headNode || null == headNode.next) {
                return headNode;
            } else {
                LinkNode temNode = headNode.next;
                LinkNode newHead = reverseSingleLink(temNode);
                headNode.next.next = headNode;
                headNode.next = null;
                return newHead;
            }
        }
    
        public static LinkNode reverseLink(LinkNode head){
            if(head == null || head.next == null){
                return head;
            }
            LinkNode prev = null;
            LinkNode next = null;
            while (head != null){
                next = head.next;
                head.next = prev;
                prev = head;
                head = next;
            }
    
            return prev;
        }
    
    }
  • 相关阅读:
    leetcode:655. 输出二叉树
    leetcode:763. 划分字母区间
    leetcode:3. 无重复字符的最长子串
    leetcode:2. 两数相加
    leetcode每日一题:409. 最长回文串
    leetcode:1381. 设计一个支持增量操作的栈
    leetcode:1380. 矩阵中的幸运数
    [数据结构] 迷宫问题(栈和队列,深搜和广搜)
    [数据结构] N皇后问题
    [2011山东ACM省赛] Sequence (动态规划)
  • 原文地址:https://www.cnblogs.com/junge/p/10021312.html
Copyright © 2020-2023  润新知