Java定义栈结构,并实现入栈、出栈操作完整示例

 更新时间:2020年02月05日 12:00:24   作者:缘故为何  
这篇文章主要介绍了Java定义栈结构,并实现入栈、出栈操作,结合完整实例形式分析了java数据结构中栈的定义、以及入栈、出栈、栈是否为空判断、栈大小计算、打印栈元素等相关操作技巧,需要的朋友可以参考下

本文实例讲述了Java定义栈结构,并实现入栈、出栈操作。分享给大家供大家参考,具体如下:

package com.example.demo;
import java.util.ArrayList;
public class Stack {
  ArrayList<Object> list = new ArrayList<>();
  //入栈
  public void push(Object o){
    list.add(o);
  }
  //出栈
  public Object pop(){
    Object o = list.get(list.size() - 1);
    list.remove(o);
    return o;
  }
  //栈是否为空
  public boolean isEmpty(){
    return list.isEmpty();
  }
  //栈大小
  public int size(){
    return list.size();
  }
  //打印栈元素
  @Override
  public String toString(){
    return String.valueOf(list);
  }
}
class main{
  public static void main(String[] args) {
    //创建一个栈
    Stack stack = new Stack();
    //入栈
    for(int i=1;i<=10;i++){
      stack.push(i);
    }
    //出栈
    while(!stack.isEmpty()){
      System.out.println("栈:" + stack.toString() + "\t栈大小为:" + stack.size() + "\t出栈元素为:" + stack.pop());
    }
  }
}

运行结果:

栈:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]    栈大小为:10    出栈元素为:10
栈:[1, 2, 3, 4, 5, 6, 7, 8, 9]    栈大小为:9    出栈元素为:9
栈:[1, 2, 3, 4, 5, 6, 7, 8]    栈大小为:8    出栈元素为:8
栈:[1, 2, 3, 4, 5, 6, 7]    栈大小为:7    出栈元素为:7
栈:[1, 2, 3, 4, 5, 6]    栈大小为:6    出栈元素为:6
栈:[1, 2, 3, 4, 5]    栈大小为:5    出栈元素为:5
栈:[1, 2, 3, 4]    栈大小为:4    出栈元素为:4
栈:[1, 2, 3]    栈大小为:3    出栈元素为:3
栈:[1, 2]    栈大小为:2    出栈元素为:2
栈:[1]    栈大小为:1    出栈元素为:1

更多关于java算法相关内容感兴趣的读者可查看本站专题:《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总

希望本文所述对大家java程序设计有所帮助。

相关文章

  • 使用自定义Json注解实现输出日志字段脱敏

    使用自定义Json注解实现输出日志字段脱敏

    这篇文章主要介绍了使用自定义Json注解实现输出日志字段脱敏,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • 一文快速掌握Java中的搜索算法和排序算法

    一文快速掌握Java中的搜索算法和排序算法

    这篇文章主要为大家详细介绍了Java中常用的搜索算法和排序算法的实现,例如二分查找、冒泡排序、选择排序等,文中的示例代码讲解详细,希望对大家有所帮助
    2023-04-04
  • 基于JavaCore文件的深入分析

    基于JavaCore文件的深入分析

    本篇文章介绍了,对JavaCore文件的深入分析。需要的朋友参考下
    2013-05-05
  • Java搜索与图论之DFS和BFS算法详解

    Java搜索与图论之DFS和BFS算法详解

    DFS指在进行算法运算时,优先将该路径的当前路径执行完毕,执行完毕或失败后向上回溯尝试其他途径。BFS指在进行算法运算时,优先将当前路径点的所有情况罗列出来,然后根据罗列出来的情况罗列下一层。本文介绍了二者的实现与应用,需要的可以参考一下
    2022-11-11
  • 优化常见的java排序算法

    优化常见的java排序算法

    这篇文章主要介绍了Java编程中快速排序算法的实现及相关算法优化,快速排序算法的最差时间复杂度为(n^2),最优时间复杂度为(n\log n),存在优化的空间,需要的朋友可以参考下
    2021-07-07
  • SpringBoot接收参数的8种方式示例详解

    SpringBoot接收参数的8种方式示例详解

    这篇文章主要介绍了SpringBoot接收参数的8种方式,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08
  • springboot使用校验框架validation校验的示例

    springboot使用校验框架validation校验的示例

    这篇文章主要介绍了springboot使用校验框架validation校验的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-02-02
  • 通过实例深入学习Java的Struts框架中的OGNL表达式使用

    通过实例深入学习Java的Struts框架中的OGNL表达式使用

    这篇文章主要通过实例介绍了Java的Strus框架中的OGNL表达式使用,Struts框架是Java的SSH三大web开发框架之一,需要的朋友可以参考下
    2015-11-11
  • Java使用BigDecimal解决小数计算问题

    Java使用BigDecimal解决小数计算问题

    Java中的BigDecimal是一个内置类,用于精确表示任意大小的十进制数,它提供了一种处理浮点运算精度问题的方法,特别适合金融、货币交易等需要高精度计算的场景,本文给大家介绍了java中如何使用BigDecimal解决小数计算问题,需要的朋友可以参考下
    2024-08-08
  • jsp中存取session值简单介绍

    jsp中存取session值简单介绍

    这篇文章主要介绍了jsp中存取session值简单介绍,涉及request和session的域操作等相关内容,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11

最新评论