JVM · Java虚拟机原理 · JVM上语言·框架· 生态系统二叉树之下Java学习笔记

剑指offer(三)从尾到头打印链表

2018-07-28  本文已影响11人  z七夜

写在前面:

为了增长一下自己的数据结构能力,也为了面试准备,准备将剑指Offer做一下,并与各位分享,希望各位可以对代码以及思路提提建议,欢迎志同道合者,谢谢。

1.剑指offer(一)二维数组中的查找
2.剑指offer(二) 替换空格

题目:
输入一个链表,按链表值从尾到头的顺序返回一个ArrayList。

思路:
输入一个链表,将链表遍历出来,用集合接受,然后翻转集合,那么就是倒着的链表,
本来是想着能不能直接从链表的尾部开始倒着遍历,直接添加到集合,但是想了一下,还是要各位帮帮忙,

代码实现

package com.itzmn.offer;

import java.util.ArrayList;
import java.util.Collections;

/**
 * @Auther: 张梦楠
 * @Date: 2018/7/27 18:41
 * 简书:https://www.jianshu.com/u/d611be10d1a6
 * 码云:https://gitee.com/zhangqiye
 * @Description:
 */
public class Offer3 {

    public static void main(String[] args) {
        new Offer3().init();
    }

    private void init() {
        ListNode listNode = new ListNode(2);
        ListNode listNode1 = new ListNode(3);
        ListNode listNode3 = new ListNode(4);

        listNode.next  = listNode1;
        listNode1.next = listNode3;
        ArrayList<Integer> integers = printListFromTailToHead(listNode);

        for (Integer integer:integers){
            System.out.println(integer);
        }
    }

    public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {

        ArrayList<Integer> integers = new ArrayList<>();
        while (listNode != null){
            integers.add(listNode.val);
            listNode = listNode.next;
        }

        Collections.reverse(integers);
        return integers;

    }



    class ListNode {
        int val;
        ListNode next = null;

        ListNode(int val) {
            this.val = val;
        }
    }
}

希望大家可以多多指点,优化一下,
QQ群:552113611

上一篇 下一篇

猜你喜欢

热点阅读