LinkedList<E> 及模拟栈结构

LinkedList<E>

LinkedList 是一个继承于AbstractSequentialList的双向链表。它也可以被当作堆栈、队列或双端队列进行操作。

栈,先进后出 
队列,先进先出

他的父类java.util.AbstractCollection 重写了toString()方法
public String toString()
	返回此 collection 的字符串表示形式。
	该字符串表示形式由 collection 元素的列表组成,
	这些元素按其迭代器返回的顺序排列,并用方括号 ("[]") 括起来。
	相邻元素由字符 ", "(逗号加空格)分隔。
	通过 String.valueOf(Object) 可以将元素转换成字符串。 
	覆盖:
	类 Object 中的 toString
	返回:
	此 collection 的字符串表示形式

public void addFirst(E e)及addLast(E e)
public E getFirst()及getLast()
public E removeFirst()及public E removeLast()
public E get(int index);


import java.util.LinkedList;
public class a {
	@SuppressWarnings({ "unchecked", "rawtypes" })
	public static void main(String[] args) {
		LinkedList list = new LinkedList();
		list.addFirst("a");
		list.addFirst("b");
		list.addFirst("c");
		list.addFirst("d");
		list.addLast("e");
		System.out.println(list);//[d, c, b, a, e]
		
		System.out.println(list.getFirst());//d
		System.out.println(list.getLast());//e
		
		System.out.println(list.removeFirst());//d
		System.out.println(list.removeLast());//e
		
		System.out.println(list.get(1));//b
		System.out.println(list);//	[c, b, a]
	}
}


用LinkedList模拟栈结构

import java.util.LinkedList;
public class b {

	@SuppressWarnings({ "rawtypes", "unchecked" })
	public static void main(String[] args) {
		LinkedList list = new LinkedList();	//创建集合对象
		list.addLast("a");
		list.addLast("b");
		list.addLast("c");
		list.addLast("d");
		
		/*System.out.println(list.removeLast());
		System.out.println(list.removeLast());
		System.out.println(list.removeLast());
		System.out.println(list.removeLast());*/
		//d c b a
		while(!list.isEmpty()) {
			System.out.println(list.removeLast());
		}
		
		
		Stack s = new Stack();
		s.in("a");	//进栈
		s.in("b");
		s.in("c");
		s.in("d");
		
		while(!s.isEmpty()) {//判断栈结构是否为空
			System.out.println(s.out());//弹栈
		}
	}

}
stack的封装

import java.util.LinkedList;
public class Stack {
	
	private LinkedList list = new LinkedList();
	/*
	 * 模拟进栈方法
	 */
	public void in(Object obj) {
		list.addLast(obj);
	}
	/*
	 * 模拟出栈
	 */
	public Object out() {
		return list.removeLast();
	}
	/*
	 * 模拟栈结构是否为空
	 */
	public boolean isEmpty() {
		return list.isEmpty();
	}
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值