【剑指offer】从尾到头打印链表

【前提】

Node定义和链表的操作代码 参照 Java 单链表操作

【解题思路-】

Java中利用栈的“”FILO“”功能完成逆向打印

private static void inversePrinting(MyLinkList linklist) {
		// TODO Auto-generated method stub
		Node node=linklist.head;
		Stack <Node> stack=new Stack<Node>();
		//System.out.println(node.value);
		while(node!=null){
			stack.push(node);
			node=node.next;	
		}
		while(!stack.isEmpty()){
		     node=stack.peek();
			System.out.print(node.value+" ");
			stack.pop();
		}
		System.out.println();
	}
【解题思路2】

利用递归思想,每次先打印当前节点以后的其他节点的内容

private static void inversePrinting_Recursively(Node phead) {
		// TODO Auto-generated method stub
		if(phead!=null){
			if(phead.next!=null){
				inversePrinting_Recursively(phead.next);
			}
			      System.out.print(phead.value+" ");
				
			}
		
	}






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值