java怎样输入一个链表_输入一个链表,按链表从尾到头的顺序返回一个ArrayList...

方案一:先逆序,再存放

import java.util.ArrayList;

public class Solution {

public ArrayList printListFromTailToHead(ListNode listNode) {

ListNode temp=null;

ListNode pre=null;

ListNode cur=listNode;

while(cur!=null){

temp=cur.next;

cur.next=pre;

pre=cur;

cur=temp;

}

ArrayList list=new ArrayList();

while(pre!=null){

list.add(pre.val);

pre=pre.next;

}

return list;

}

}

方案二采用栈

import java.util.*;

import java.util.ArrayList;

public class Solution {

public ArrayList printListFromTailToHead(ListNode listNode) {

Stack stack = new Stack();

ListNode temp=listNode;

while(temp!=null){

stack.push(temp.val);

temp=temp.next;

}

ArrayList list= new ArrayList();

while(!stack.isEmpty())

list.add(stack.pop());

return list;

}

}

方案三:采用递归的思想

import java.util.*;

import java.util.ArrayList;

public class Solution {

ArrayList list=new ArrayList();

public ArrayList printListFromTailToHead(ListNode listNode) {

f(listNode);

return list;

}

public void f(ListNode node){

if(node==null)

return;

f(node.next);

list.add(node.val);

}

}

结果对比:

方案 时间 内存

方案一 20ms 9348

方案二 22ms 9464

方案三 21ms 9344

结果对比好像差不多:递归的方案更加简洁

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值