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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • django笔记_django 异步

    django笔记_django 异步前言Django是一个开放源代码的Web应用框架,由Python写成,最初用于管理劳伦斯出版集团旗下的一些以新闻内容为主的网站,即CMS(内容管理系统)软件,于2005年7月在BSD许可证下发布,这

    2022年7月31日
    8
  • 山东省计算机考试模拟,山东省高校计算机等级考试VB考试模拟系统使用说明

    山东省计算机考试模拟,山东省高校计算机等级考试VB考试模拟系统使用说明

    2021年11月28日
    38
  • Bug.PotPlayer播放视频上下、左右翻转

    Bug.PotPlayer播放视频上下、左右翻转2018/8/8 PotPlayer作为一款全能、绿色的视频播放器倍受喜爱。在使用中偶尔可能会出现播放视频上下倒置、左右翻转的情况,一时让人摸不着头脑。其实是误触了快捷键导致图像颠倒,再次按下快捷键即可恢复。上下倒置的情况,这时在播放界面按下“Ctrl+V”快捷键;界面左上角提示“图像上下翻转:关闭”,视频播放恢复正常。左右翻转时,如果无字幕其实并不影响观看;这时按下快捷键“Ctrl+…

    2022年5月12日
    166
  • 开撕!赛门铁克抨击 Google 夸大其词误导用户「建议收藏」

    开撕!赛门铁克抨击 Google 夸大其词误导用户

    2022年3月3日
    44
  • 简单说说USB协议(一)[通俗易懂]

    简单说说USB协议(一)[通俗易懂]USB,通用串行总线,是一种计算机与外围设备进行数据交互的通信协议。任何东西的出现都是有理可循的,在以前计算机刚兴起的时候,要连接一个新的设备,需要断电关闭计算机,连接好设备,配置好硬件,再上电运行,这个过程相当费时费力,为了能拥有随意接入设备这种热拔插特性,USB总线协议应运而生。USB总线如今已经有USB1.0、USB1.1、USB2.0、USB3.0。USB协议采用主从工作模式,…

    2022年6月17日
    38
  • C++ merge函数

    C++ merge函数C++merge函数首先,merge()函数调用前必须保L1,L2是有序的,然后才能调用merge()函数。所以应该做两处更改:1.在worker类的公有函数中添加以下定义排序准则的函数。booloperator&lt;(constworker&amp;kk) { returnthis-&gt;age&lt;kk.getAge(); }2.在调用…

    2022年6月7日
    146

发表回复

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

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