java栈方法_java栈的两种实现方法[通俗易懂]

java栈方法_java栈的两种实现方法[通俗易懂]java栈的实现有两种方式:一.使用数组来实现://使用数组实现栈,功能包括进行内存扩展publicclassStack{privateint[]data;privateintlength;//表示初始化栈的内存长度privateinttop;//用来表示栈的实际长度privatefinalintexpandLength=20;//表示扩展的长度publicStack(i…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

java栈的实现有两种方式:

一.使用数组来实现://使用数组实现栈,功能包括进行内存扩展

public class Stack {

private int []data;

private int length;//表示初始化栈的内存长度

private int top;//用来表示栈的实际长度

private final int expandLength=20;//表示扩展的长度

public Stack(int length){

this.length=length;

top=-1;//初始化为-1

data=new int[length];

}

//压栈

public void push(int value){

if(top

data[++top]=value;

else{

//进行内存扩展

int []temp=new int[length+expandLength];

for(int i=0;i

temp[i]=data[i];

}

data=temp;

data[++top]=value;

}

}

//出栈

public int pop(){

return data[top–];

}

//返回栈头元素

public int peek(){

return data[top];

}

//返回栈的长度

public int getLength(){

return top+1;

}

//判断是否为满

public boolean isfull(){

return(top==length-1);

}

}

二.使用数组线性表来实现栈://使用线性表实现栈的存储,这样不需要考虑内存扩展的情况

import java.util.*;

public class linkedStack {

private LinkedList Linkedlist;//定义一个线性表

public linkedStack(){

Linkedlist=new LinkedList();

}

//压栈

public void push(T value){

Linkedlist.add(value);

}

//出栈

public T pop(){

T data=Linkedlist.get(getLength()-1);

Linkedlist.remove(getLength()-1);

return data;

}

//得到栈头元素

public T peek(){

return Linkedlist.get(Linkedlist.size()-1);

}

//栈的长度

public int getLength(){

return Linkedlist.size();

}

}

就我个人而言,我更喜欢第二种实现方法,第二种可以自己定义所要存储的数据类型,有人会说为啥第一种方法不用泛型,我有试过,但是会非常麻烦。首先泛型对数组的定义本来就要限制,所以综合考虑,本人就在第一种方法中简化了,定义数据类型为int类型.如果大家有更好的方法,希望能提出,相互提高,这里仅仅表明我个人的想法。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196828.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 一阶惯性环节matlab编程_matlab一阶惯性环节

    一阶惯性环节matlab编程_matlab一阶惯性环节该楼层疑似违规已被系统折叠隐藏此楼查看此楼我照着网上的程序自己改出来的程序是这样的clc;clear;ts=0.001;%采样时间sys=tf(-53,[19926,100],’ioDelay’,540);%tf是传递函数,用来实现G(s);在自动控制领域经常用到,dsys=c2d(sys,ts,’z’);%把控制函数离散化,转化…

    2022年10月4日
    3
  • a算法解决八数码实验报告_人工智能常用算法模型

    a算法解决八数码实验报告_人工智能常用算法模型实验一A*算法求解8数码问题一、实验目的熟悉和掌握启发式搜索的定义、估价函数和算法过程,并利用A*算法求解N数码难题,理解求解流程和搜索顺序。二、实验原理A*算法是一种启发式图搜索算法,其特点在于对估价函数的定义上。对于一般的启发式图搜索,总是选择估价函数f值最小的节点作为扩展节点。因此,f是根据需要找到一条最小代价路径的观点来估算节点的,所以,可考虑每个节点n的估价函数值为两个分量:从起始节点到节点n的实际代价g(n)以及从节点n到达目标节点的估价代价h(n),且hn≤h*n,h*n

    2025年6月14日
    1
  • Java 集合

    Java 集合

    2021年10月7日
    42
  • 爱奇艺需要优化的功能_爱奇艺怎么调三倍速度

    爱奇艺需要优化的功能_爱奇艺怎么调三倍速度爱奇艺技术分享:爱奇艺Android客户端启动速度优化实践总结

    2022年4月21日
    64
  • IDEA 离线安装lombok插件

    IDEA 离线安装lombok插件IDEA 离线安装 lombok 插件

    2026年1月22日
    4
  • JLink、JTAG接口详细图解「建议收藏」

    JLink、JTAG接口详细图解「建议收藏」说明:1脚:通常连接到目标板的vdd,用来检测目标系统是否供电;检测原理上图中有简单的说明。2脚:原版的JLink这个引脚没有使用,不提供Vsupply输出,而很多改造版的JLink通过跳线选择从该引脚输出3.3V的电压给外边,我的就是这样的。可以到网上找JLink的原理图看看。http://infocenter.arm.com/help/index.jsp?top

    2022年5月27日
    267

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号