全部
常见问题
产品动态
精选推荐

【Java-数据结构篇】Java 中栈和队列:构建程序逻辑的关键数据结构

管理 管理 编辑 删除

在 Java 中,栈和队列是两种重要的数据结构,它们在构建程序逻辑时起着关键作用。以下是对这两种数据结构的详细介绍:


### 栈 (Stack)

- **定义**:栈是一种后进先出(LIFO, Last In First Out)的数据结构。元素只能从栈顶插入和删除。

- **常用操作**:

 - `push`:将元素压入栈顶。

 - `pop`:从栈顶弹出元素。

 - `peek`:查看栈顶元素但不弹出。

- **应用场景**:

 - **函数调用栈**:用于管理函数调用和返回。

 - **表达式求值**:用于中缀表达式转后缀表达式和计算后缀表达式的值。

 - **括号匹配**:用于检查括号是否成对匹配。


示例代码:

```java

import java.util.Stack;


public class StackExample {

   public static void main(String[] args) {

       Stack stack = new Stack<>();

       stack.push(1);

       stack.push(2);

       stack.push(3);

       System.out.println("Stack: " + stack);

       System.out.println("Popped element: " + stack.pop());

       System.out.println("Top element: " + stack.peek());

   }

}

```


### 队列 (Queue)

- **定义**:队列是一种先进先出(FIFO, First In First Out)的数据结构。元素只能从队尾插入,从队首删除。

- **常用操作**:

 - `offer`:将元素插入队尾。

 - `poll`:从队首删除元素。

 - `peek`:查看队首元素但不删除。

- **应用场景**:

 - **任务调度**:用于管理任务的执行顺序。

 - **广度优先搜索**:用于图的广度优先搜索算法。

 - **缓冲区**:用于数据流的缓冲区管理。


示例代码:

```java

import java.util.LinkedList;

import java.util.Queue;


public class QueueExample {

   public static void main(String[] args) {

       Queue queue = new LinkedList<>();

       queue.offer(1);

       queue.offer(2);

       queue.offer(3);

       System.out.println("Queue: " + queue);

       System.out.println("Polled element: " + queue.poll());

       System.out.println("Front element: " + queue.peek());

   }

}

```


总结

- **栈**:后进先出,适用于函数调用管理、表达式求值和括号匹配等场景。

- **队列**:先进先出,适用于任务调度、广度优先搜索和缓冲区管理等场景。


请登录后查看

小码二开 最后编辑于2024-12-06 11:02:05

快捷回复
回复
回复
回复({{post_count}}) {{!is_user ? '我的回复' :'全部回复'}}
排序 默认正序 回复倒序 点赞倒序

{{item.user_info.nickname ? item.user_info.nickname : item.user_name}} LV.{{ item.user_info.bbs_level }}

作者 管理员 企业

{{item.floor}}# 同步到gitee 已同步到gitee {{item.is_suggest == 1? '取消推荐': '推荐'}}
{{item.is_suggest == 1? '取消推荐': '推荐'}}
沙发 板凳 地板 {{item.floor}}#
{{item.user_info.title || '暂无简介'}}
附件

{{itemf.name}}

{{item.created_at}}  {{item.ip_address}}
{{item.like_count}}
{{item.showReply ? '取消回复' : '回复'}}
删除
回复
回复

{{itemc.user_info.nickname}}

{{itemc.user_name}}

回复 {{itemc.comment_user_info.nickname}}

附件

{{itemf.name}}

{{itemc.created_at}}
{{itemc.like_count}}
{{itemc.showReply ? '取消回复' : '回复'}}
删除
回复
回复
查看更多
130
{{like_count}}
{{collect_count}}
添加回复 ({{post_count}})

相关推荐

快速安全登录

使用微信扫码登录
{{item.label}} 加精
{{item.label}} {{item.label}} 板块推荐 常见问题 产品动态 精选推荐 首页头条 首页动态 首页推荐
取 消 确 定
回复
回复
问题:
问题自动获取的帖子内容,不准确时需要手动修改. [获取答案]
答案:
提交
bug 需求 取 消 确 定

微信登录/注册

切换手机号登录

{{ bind_phone ? '绑定手机' : '手机登录'}}

{{codeText}}
切换微信登录/注册
暂不绑定
CRMEB客服

CRMEB咨询热线 咨询热线

400-8888-794

微信扫码咨询

CRMEB开源商城下载 源码下载 CRMEB帮助文档 帮助文档
返回顶部 返回顶部
CRMEB客服