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

JAVA 100道题(14)

14.使用LinkedList实现一个简单的堆栈(Stack)数据结构。

下面是一个简单的Java程序,使用LinkedList来实现一个堆栈(Stack)数据结构。在这个程序中,我们定义了一个MyStack类,它包含了一些基本的堆栈操作,如push(压栈)、pop(出栈)、peek(查看栈顶元素)和isEmpty(检查堆栈是否为空)。

 

java复制代码

import java.util.LinkedList;
public class MyStack<T> {
private LinkedList<T> stack;
public MyStack() {
this.stack = new LinkedList<>();
}
// 压栈操作
public void push(T item) {
stack.addFirst(item);
}
// 出栈操作
public T pop() {
if (!isEmpty()) {
return stack.removeFirst();
} else {
throw new RuntimeException("Stack is empty");
}
}
// 查看栈顶元素
public T peek() {
if (!isEmpty()) {
return stack.getFirst();
} else {
throw new RuntimeException("Stack is empty");
}
}
// 检查堆栈是否为空
public boolean isEmpty() {
return stack.isEmpty();
}
// 打印堆栈内容
public void printStack() {
System.out.println(stack);
}
public static void main(String[] args) {
MyStack<Integer> stack = new MyStack<>();
// 压栈操作
stack.push(1);
stack.push(2);
stack.push(3);
// 打印堆栈内容
stack.printStack();
// 查看栈顶元素
System.out.println("Top element: " + stack.peek());
// 出栈操作
stack.pop();
// 打印堆栈内容
stack.printStack();
// 检查堆栈是否为空
System.out.println("Is stack empty? " + stack.isEmpty());
}
}

在这个程序中,我们创建了一个MyStack类,并使用LinkedListaddFirst方法来实现压栈操作,removeFirst方法来实现出栈操作,getFirst方法来实现查看栈顶元素的操作。在main方法中,我们创建了一个MyStack对象,并进行了一些基本的堆栈操作,包括压栈、查看栈顶元素、出栈和检查堆栈是否为空。

http://www.lryc.cn/news/324478.html

相关文章:

  • STM32+ESP8266水墨屏天气时钟:简易多级菜单(数组查表法)
  • 数学建模综合评价模型与决策方法
  • window下安装并使用nvm(含卸载node、卸载nvm、全局安装npm)
  • Mysql——基础命令集合
  • 记录一次流相关故障
  • linux源配置:ubuntu、centos;lspci与lsmod命令区别
  • 面试算法-88-反转链表
  • 如何在个人Windows电脑搭建Cloudreve云盘并实现无公网IP远程访问
  • 一文详解Rust中的字符串
  • Mysql中用户密码修改
  • day14-SpringBoot 原理篇
  • ChatGPT论文指南|揭秘8大ChatGPT提示词研究技巧提升写作效率【建议收藏】
  • P1563 [NOIP2016 提高组] 玩具谜题
  • 【数据库】数据库语言
  • javascript单例模式字面量定义的接口和匿名函数定义的接口;他们之间访问私有变量和私有函数之间的区别
  • 啥是大语言模型LLM
  • vue3之路由导航故障
  • Dr4g0n
  • 蓝桥杯每日一题:扫雷
  • net core API 后台系统操作日志的实现思路
  • ORACLE 知识整理
  • 业务服务:redisson
  • 面试算法-100-零钱兑换
  • 【Leetcode每日一题】 动态规划 - 使用最小花费爬楼梯(难度⭐)(41)
  • Springboot旅游管理系统设计与实现
  • c++学习笔记(10)
  • Visual Studio - 添加快捷键图标
  • 突破边界:Web3开启数字化社会的新纪元
  • docker仓库登录及配置insecure-registries的方法
  • Lambda函数与Selenium WebDriverWait类一起使用