当前位置: 首页 > news >正文

网站建设7个基网站的标题标签一般是写在

网站建设7个基,网站的标题标签一般是写在,沈阳网站制作公司排名,马来西亚网站建设目录 一.栈(Stack) 1.1栈的概念 1.2栈的实现及模拟 二.队列(Queue) 2.1队列的概念 2.2队列的实现及模拟 2.3循环队列 2.4双端队列(Deque) 一.栈(Stack) 1.1栈的概念 栈:一种特殊的线性表,其 只允许在固定的一端进行插入和删除元素操作…

目录

一.栈(Stack)

1.1栈的概念

1.2栈的实现及模拟

二.队列(Queue)

2.1队列的概念

2.2队列的实现及模拟 

 2.3循环队列

2.4双端队列(Deque)


一.栈(Stack)

1.1栈的概念

栈:一种特殊的线性表,其 只允许在固定的一端进行插入和删除元素操作 。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO Last In First Out )的原则 
压栈:栈的插入操作叫做进栈 / 压栈 / 入栈, 入数据在栈顶
出栈:栈的删除操作叫做出栈。 出数据在栈顶

 

1.2栈的实现及模拟

public class Test {public static void main(String[] args) {Stack<Integer>s=new Stack();//创建一个空栈s.push(1);//往栈中存入1s.push(2);//2s.push(3);//3s.push(4);//4s.push(5);//5System.out.println(s.size());//有效个数5System.out.println(s.peek());//获取栈顶元素5s.pop();//5出栈System.out.println(s.peek());//此时栈顶元素变为4System.out.println(s.empty());//判断是否为空栈,此时不为空 返回false}
}

 这里我们用自己的方法来模拟实现上述的方法

public class MyStack {int[] elem;int usedSize;public MyStack(){this.elem=new int[10];}public void push(int val){if(isFull()){//扩容elem= Arrays.copyOf(elem,elem.length*2);}elem[usedSize]=val;usedSize++;}public boolean isFull(){return usedSize==elem.length;}public int pop(){if(empty()){return -1;}int oldVal=elem[usedSize-1];usedSize--;return oldVal;}public int peek(){if(empty()){return -1;}return elem[usedSize-1];}public boolean empty(){return usedSize==0;}
}

二.队列(Queue)

2.1队列的概念

队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出FIFO(First In First Out) 入队列:进行插入操作的一端称为队尾(Tail/Rear) 出队列:进行删除操作的一端称为队头(Head/Front)

 

2.2队列的实现及模拟 

在Java中,Queue是个接口,底层是通过链表实现的

注意:Queue是个接口,在实例化时必须实例化LinkedList的对象,因为LinkedList实现了Queue接口。 

public class Test{public static void main(String[] args) {Queue<Integer>q=new LinkedList<>();q.offer(1);//从队尾入q.offer(2);q.offer(3);q.offer(4);System.out.println(q.size());//有效个数 4System.out.println(q.peek());//获取头元素 1q.poll();//1从队列中出System.out.println(q.peek());//2System.out.println(q.isEmpty());//此时队列不为空,所以返回 false}
}

这里我们进行模拟实现上述方法 

public class MyQueue {static class ListNode{public int val;public ListNode prev;public ListNode next;public ListNode(int val){this.val=val;}}public ListNode head;public ListNode last;public void offer(int val){ListNode node=new ListNode(val);if(head==null){head=last=node;}else{last.next=node;node.prev=last;last=last.next;}}public int poll(){if(head==null){return -1;}int ret=head.val;if(head.next==null){head=last=null;}else{head=head.next;head.prev=null;}return ret;}public int peek(){if(head == null) {return -1;}return head.val;}public boolean isEmpty(){return head==null;}
}

 2.3循环队列

实际中我们有时还会使用一种队列叫循环队列。如操作系统课程讲解生产者消费者模型时可以就会使用循环队列。环形队列通常使用数组实现。

2.4双端队列(Deque)

双端队列(deque)是指允许两端都可以进行入队和出队操作的队列,deque 是 “double ended queue” 的简称。

那就说明元素可以从队头出队和入队,也可以从队尾出队和入队

Deque是一个接口,使用时必须创建LinkedList的对象
 

Deque<Integer> stack = new ArrayDeque<>();//双端队列的线性实现
Deque<Integer> queue = new LinkedList<>();//双端队列的链式实现  

我将在下篇文章详细讲解这两种队列的使用以及相关OJ题 


如果上述内容对您有帮助,希望给个三连谢谢!

 

http://www.yayakq.cn/news/988430/

相关文章:

  • 地产平面网站合肥做网站的公司
  • 做任务可以给钱的网站合肥今天发现了一例病例吗
  • 做屏保那个网站下载图好种子资源
  • 做网站需要备几个案群晖wordpress修改80端口
  • 咖啡网站设计模板公司网站建设必要性
  • 南京做企业网站wordpress 08影院模板
  • 酒类公司网站模板纯静态网站 搜索功能
  • 证券网站开发凡客建站登陆
  • 有趣的网站代码对门户网站建设的见解
  • h5响应式网站模板下载租房网站那些地图区域统计怎么做的
  • 输入搜索内容做seo网站的步骤
  • 内网网站建设的步骤过程做团购的网站
  • 北京建设网站图片中国建设银行手机银行下载官方网站
  • 网站设计原则的第三要素百度关键字怎么搜到公司网站
  • 基于ssh框架的网站开发流程html5网站建设基本流程图
  • 无锡装修网站河南网站优化公司
  • 做怎样的网站能赚钱仿淘宝商城网站开源系统
  • 有什么网站是做投资的服饰技术支持 东莞网站建设
  • dede网站mipwordpress dokuwiki
  • 门户网站建设如何入账橙色的网站模板
  • 韩国原生ip站群服务器公众号怎么推广快又有效
  • win8风格门户网站制作企业网站的基本步骤
  • 个人备案的网站可以做商城wordpress 文章换行
  • 公司网站注销商品展示网站源码
  • 建筑设计师专业网站深圳市宝安区龙华公司是干什么的
  • 厦门网站排名优化价格久久建筑服务网
  • 个人网站做得优秀的百度网盘登录首页
  • 做模版网站需要租服务器吗企业网站推广的方法有什么
  • 网站淘客宝怎么做建网站自己与租云服务器哪个好
  • 网站建设方案书泰安网红金火火