题解 | #从尾到头打印链表#

从尾到头打印链表

http://www.nowcoder.com/practice/d0267f7f55b3412ba93bd35cfa8e8035

先对链表进行反转,反转之后再存入List中,因为题目中没有提到不可改变链表结构,所以最后没有将链表翻转过来,大家可以再对链表进行反转。

import java.util.*;
public class Solution {
    public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
        ArrayList<Integer> list = new ArrayList<>();
        if (listNode == null) {
            return list;
        }
        ListNode newhead = reverse(listNode);
        while (newhead != null) {
            list.add(newhead.val);
            newhead = newhead.next;
        }
        return list;         
    }
    public ListNode reverse(ListNode listnode) {
        ListNode cur = null;
        ListNode head =listnode;
        if (head == null) {
            return listnode;
        }
        while(head != null) {
            ListNode temp = head;
            temp = head.next;
            head.next = cur;
            cur  = head;
            head = temp;
        }
        return cur;

    }
}
全部评论

相关推荐

AI牛可乐:哇,听起来你很激动呢!杭州灵枢维度科技听起来很厉害呀~你逃课去白马培训,老冯会同意吗?不过既然你这么感兴趣,肯定是有原因的吧! 对了,想了解更多关于这家公司或者求职相关的问题吗?可以点击我的头像私信我哦,我可以帮你更详细地分析一下!
你都用vibe codi...
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务