java栈的实现_java技术栈

java栈的实现_java技术栈一.数组实现的栈,能存储任意类型的数据。/***java使用数组来实现栈,能存储任意数据**@authorLinging*@date2019/2/10**/importjava.lang.reflect.Array;publicclassArrayStack<T>{ privatefinalstaticintDEFA…

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

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

一.数组实现的栈,能存储任意类型的数据。

/** * java 使用数组来实现栈,能存储任意数据 * * @author Linging * @date 2019/2/10 * */
import java.lang.reflect.Array;

public class ArrayStack<T> { 
   
	
	private final static int DEFAULT_SIZE = 10;    //栈的默认大小
	private T[] mArray;    			//栈的数组结构
	private int top;				//栈“指针”
	private int count;				//栈中元素的个数

	public ArrayStack(Class<T> type) { 
   
		//调用下面的构造函数
		this(type, DEFAULT_SIZE);
	}
	
	public ArrayStack(Class<T> type, int size) { 
   
		//通过java反射机制创建动态数组
	[链接](https://blog.csdn.net/e421083458/article/details/8839311)
		mArray = (T[])Array.newInstance(type, DEFAULT_SIZE);
		count = 0;
		top = -1;
	}
	
	//进栈
	public void push(T data) { 
   
		mArray[++top] = data;
		count++;
	}
	
	//判断栈是否为空
	public boolean isEmpty() { 
   
		return top == -1;
	}
	
	//判断栈是否满
	public boolean isFull() { 
   
		return count == DEFAULT_SIZE;
	}
	
	//出栈
	public T pop() { 
   
		T m = mArray[top];
		top--; count--;
		return m;
	}
	
	//获取栈顶元素,不删除栈顶元素
	public T peek() { 
   
		return mArray[count-1];
	}
	
	//打印栈
	public void print() { 
   
		if(!isEmpty()) { 
   
			for(int i = 0; i <= top; i++) { 
   
				System.out.println(mArray[i]);
			}
		}
		System.out.println("count="+count);
	}
	

	public static void main(String[] args) { 
   
		// TODO Auto-generated method stub
		ArrayStack<String> stack = new ArrayStack<String>(String.class);
		//依次进栈10,20,30
		System.out.println("依次进栈:");
		stack.push("10");
		stack.push("20");
		stack.push("30");
		
		//打印栈
		stack.print();
		
		//获取栈顶元素
		System.out.println("栈顶元素为:"+stack.peek());
		
		//判断栈是否为空
		System.out.println("isEmpty:"+stack.isEmpty());
		
		//判断栈是否为满
		System.out.println("isFull:"+stack.isFull());
		
		//依次出栈
		System.out.println("\n"+"依次出栈:");
		System.out.println(stack.pop());
		System.out.println(stack.pop());
		System.out.println(stack.pop());
		stack.print();
		System.out.println("isEmpty:"+stack.isEmpty());
		System.out.println("isFull:"+stack.isFull());
	}

}

二.java的Collection中的stack演示。

/** * java Collection中的stack * * @date 2019/2/10 * @author Linging * */

import java.util.Stack;

public class CollectionStack { 
   

	public static void main(String[] args) { 
   
		// TODO Auto-generated method stub
		Stack<String> stack = new Stack<String>();
		
		//进栈
		stack.push("100");
		stack.push("200");
		stack.push("300");
		
		//输出栈顶元素,不删除栈顶元素。
		System.out.println("1栈顶元素为:"+stack.peek());
		
		//输出栈顶元素,删除栈顶元素。
		System.out.println("2栈顶元素为:"+stack.pop());
		
		System.out.println("栈中元素个数:"+stack.size());
		
		stack.push("400");
		
		//依次出栈
		System.out.println("依次出栈:");
		while(!stack.isEmpty()) { 
   
			System.out.println(stack.pop());
		}
		System.out.println("栈中元素个数:"+stack.size());
	}

}

学习自:http://www.cnblogs.com/skywang12345/p/3562239.html

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

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

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


相关推荐

  • gluster源码浅析

    gluster源码浅析gluster的volume是由一系列的translator组成的,translator就像输入输出流的堆栈式结构一样,由一个translator调用另一个translator,每个translator在运行时作为shared-object,根据不同的文件操作调用不同的函数.每个translator一般需要定义xlator_fops、xlator_cbks、init、fini、volume…

    2025年6月8日
    2
  • 黄聪:使用srvany.exe将任何程序作为Windows服务运行「建议收藏」

    黄聪:使用srvany.exe将任何程序作为Windows服务运行「建议收藏」srvany.exe是什么?srvany.exe是MicrosoftWindowsResourceKits工具集的一个实用的小工具,用于将任何EXE程序作为Windows服务运行。也就是说srvany只是其注册程序的服务外壳,这个特性对于我们来说非常实用,我们可以通过它让我们的程序以SYSTEM账户启动,或者实现随机器启动而自启动,也可以隐藏不必要的窗口,比如说控制台窗口等等。如何获…

    2022年6月4日
    27
  • bass reducer什么意思_map filter foreach区别

    bass reducer什么意思_map filter foreach区别对于一些环境变量的配置文件,如想使更改后立即生效,多用souce+file执行后即可。如/etc/profile里加了配置,source和bash的区别:sourcefilenam

    2022年8月5日
    5
  • c++入门教程–-2基本语法

    c++入门教程–-2基本语法

    2021年3月12日
    108
  • python读取pkl_Python 读取文件

    python读取pkl_Python 读取文件使用python读取pkl文件内容可能会出现一些错误,下面将介绍一些解决的方法。importcPicklef=open(‘subj0.pkl’)#文件所在路径inf=cPickle.load(f)#读取pkl内容printinff.close()有时候,还是出现错误EOFEORROR,可以通过合并第2,3行,即:inf=cPickle.load(open(‘subj

    2025年10月12日
    5
  • linux(3) 处理目录的常用命令「建议收藏」

    linux(3) 处理目录的常用命令「建议收藏」目录命令总览ls(英文全拼:listfiles):列出目录及文件名cd(英文全拼:changedirectory):切换目录pwd(英文全拼:printworkdirectory):显

    2022年8月6日
    9

发表回复

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

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