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

作者: z七夜 | 来源:发表于2018-07-28 09:37 被阅读11次

写在前面:

为了增长一下自己的数据结构能力,也为了面试准备,准备将剑指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

相关文章

网友评论

    本文标题:剑指offer(三)从尾到头打印链表

    本文链接:https://www.haomeiwen.com/subject/ouonmftx.html