大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新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类型.如果大家有更好的方法,希望能提出,相互提高,这里仅仅表明我个人的想法。
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/196828.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...