集合4——LinkedList

LinkedList:底层使用了链表实现,具备的特点是查询速度慢,增删块

LinkedList中特有的方法:
一、方法
1.addFirst(E e):把元素添加到集合的首位置

LinkedList list=new LinkedList();
  list.add("狗娃");
  list.add("狗剩");
  list.addFirst("铁蛋");
  System.out.println(list);

在这里插入图片描述
2.addLast(E e):把元素添加到集合的末位置

LinkedList list=new LinkedList();
  list.add("狗娃");
  list.add("狗剩");
  list.addLast("张三");
  System.out.println(list);

在这里插入图片描述
3.getFirst():获取集合中首位置元素

LinkedList list=new LinkedList();
  list.add("狗娃");
  list.add("狗剩");
  list.addLast("张三");
  System.out.println(list.getFirst());

在这里插入图片描述
4.getLast():获取集合中末位置元素

LinkedList list=new LinkedList();
  list.add("狗娃");
  list.add("狗剩");
  list.add("铁蛋");
  System.out.println(list.getLast());

在这里插入图片描述
5.removeFirst():删除集合中首位置元素并返回

LinkedList list=new LinkedList();
  list.add("狗娃");
  list.add("狗剩");
  list.add("铁蛋");
  System.out.println(list.removeFirst());

在这里插入图片描述
6.removeLast():删除集合中末位置元素并返回

 LinkedList list=new LinkedList();
  list.add("狗娃");
  list.add("狗剩");
  list.add("铁蛋");
  System.out.println(list.removeLast());

在这里插入图片描述

二、数据结构
1.栈 : 主要用于实现堆栈数据结构的存储方式,存储数据特点:先进后出,后进先出
push()将元素插入到集合的开头处
pop()移除并返回集合中的第一个元素
2.队列 :主要可以使用LinkedList模拟队列数据结构,存储数据特点:先进先出,后进后出
offer()将元素添加到集合末尾处
poll()删除集合中的首位置元素

使用LinkedList实现堆栈数据结构的存储方式和队列数据结构储存结构

//堆栈
class StackList{
 LinkedList list;
 public StackList(){
  list=new LinkedList();
 }
 //进栈
 public void add(Object o){
  list.push(o);
 }
 //出栈
 public Object pop(){
  return list.pop();
 } 
 public int size(){
  return list.size();
 }
}
//队列
class TeamList{
 LinkedList list;
 public TeamList(){
  list=new LinkedList();
 }
 //进队
 public void add(Object o){
  list.offer(o);
 }
 //出队
 public Object remove(){
  return list.poll();
 }
 public int size(){
  return list.size();
 }
}
public class Demo2 {
 public static void main(String[] args) {
  // TODO Auto-generated method stub
  //堆栈,先进后出
  StackList list=new StackList();
  list.add("张三");
  list.add("李四");
  list.add("王五");
  int size=list.size();
  for(int i=0;i<size;i++){
   System.out.print(list.pop()+",");
  }
  System.out.println();
  //队列,先进先出
  TeamList list2=new TeamList();
  list2.add("张三");
  list2.add("李四");
  list2.add("王五");
  int size2=list2.size();
  for(int i=0;i<size2;i++){
  System.out.print(list2.remove()+",");
  }
 }
}

在这里插入图片描述
三、返回逆序的迭代器对象
descendingIterator()

LinkedList list=new LinkedList();
  list.add("狗娃");
  list.add("狗剩");
  list.add("铁蛋");
  Iterator it=list.descendingIterator();
  while(it.hasNext()){
   System.out.print(it.next()+",");//逆序
  }

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值