Java數(shù)據(jù)結(jié)構(gòu)之棧的基本定義與實(shí)現(xiàn)方法示例
本文實(shí)例講述了Java數(shù)據(jù)結(jié)構(gòu)之棧的基本定義與實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
一、概述:
1、基本概念:
棧是一種數(shù)據(jù)結(jié)構(gòu),是只能在某一端插入和刪除的特殊線性表。它按照后進(jìn)先出的原則存儲(chǔ)數(shù)據(jù),先進(jìn)入的數(shù)據(jù)被壓入棧底,最后的數(shù)據(jù)在棧頂,需要讀數(shù)據(jù)的時(shí)候從棧頂開(kāi)始彈出數(shù)據(jù)(最后一個(gè)數(shù)據(jù)被第一個(gè)讀出來(lái))。
棧是允許在同一端進(jìn)行插入和刪除操作的特殊線性表。允許進(jìn)行插入和刪除操作的一端稱(chēng)為棧頂(top),另一端為棧底(bottom);棧底固定,而棧頂 浮動(dòng);棧中元素個(gè)數(shù)為零時(shí)稱(chēng)為空棧。插入一般稱(chēng)為進(jìn)棧(PUSH),刪除則稱(chēng)為退棧(POP)。 棧也稱(chēng)為先進(jìn)后出表。
??梢杂脕?lái)在函數(shù)調(diào)用的時(shí)候存儲(chǔ)斷點(diǎn),做遞歸時(shí)要用到棧!
2、示例圖:

二、代碼實(shí)現(xiàn):
package com.java.stack;
/**
* @描述 棧示例
* @項(xiàng)目名稱(chēng) Java_DataStruct
* @包名 com.java.stack
* @類(lèi)名 MyStack
* @author chenlin
* @version 1.0
*/
public class CharStack {
private int maxSize;// 站的大小
private char[] arr;
private int top;// 指向棧頂元素
public CharStack(int size) {
this.maxSize = size;
this.arr = new char[maxSize];
this.top = -1;
}
/**
* 壓入數(shù)據(jù)
*
* @param value
*/
public void push(char value) {
arr[++top] = value;
}
/**
* 彈出數(shù)據(jù)
*
* @param value
*/
public char pop() {
return arr[top--];
}
/**
* 訪問(wèn)數(shù)據(jù)
*
* @return
*/
public long peek() {
return arr[top];
}
/**
* 判斷是否為空
*
* @return
*/
public boolean isEmpty() {
return (top == -1);
}
/**
* 是否滿(mǎn)了
*
* @return
*/
public boolean isFull() {
return (top == maxSize - 1);
}
/**
* 把字符串反序
*
* @param text
* @return
*/
public String reverse(String text) {
for (int i = 0; i < text.length(); i++) {
push(text.charAt(i));
}
String result = "";
while (!isEmpty()) {
result += (char)pop();
}
return result;
}
public static void main(String[] args) {
CharStack stack = new CharStack(30);
while (!stack.isFull()) {
stack.push('l');
stack.push('a');
stack.push('k');
stack.push('m');
stack.push('n');
stack.push('e');
stack.push('b');
stack.push('f');
stack.push('d');
stack.push('e');
}
System.out.println("腳本之家測(cè)試結(jié)果:");
System.out.println("----------------------------彈出----------------------------");
while (!stack.isEmpty()) {
System.out.println(stack.pop());
}
System.out.println("----------------------------反序----------------------------");
System.out.println(stack.reverse("abcdefg"));
}
}
運(yùn)行結(jié)果:

更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。
- Java數(shù)據(jù)結(jié)構(gòu)之紅黑樹(shù)的真正理解
- Java數(shù)據(jù)結(jié)構(gòu)之簡(jiǎn)單的連接點(diǎn)(link)實(shí)現(xiàn)方法示例
- Java數(shù)據(jù)結(jié)構(gòu)之簡(jiǎn)單鏈表的定義與實(shí)現(xiàn)方法示例
- Java數(shù)據(jù)結(jié)構(gòu)之雙端鏈表原理與實(shí)現(xiàn)方法
- java數(shù)據(jù)結(jié)構(gòu)之二分查找法 binarySearch的實(shí)例
- java 數(shù)據(jù)結(jié)構(gòu)中棧和隊(duì)列的實(shí)例詳解
- 詳解Java數(shù)據(jù)結(jié)構(gòu)和算法(有序數(shù)組和二分查找)
- java編程實(shí)現(xiàn)求解八枚銀幣代碼分享
相關(guān)文章
SpringBoot集成RocketMQ發(fā)送事務(wù)消息的原理解析
RocketMQ 的事務(wù)消息提供類(lèi)似 X/Open XA 的分布事務(wù)功能,通過(guò)事務(wù)消息能達(dá)到分布式事務(wù)的最終一致,這篇文章主要介紹了SpringBoot集成RocketMQ發(fā)送事務(wù)消息,需要的朋友可以參考下2022-06-06
基于java時(shí)區(qū)轉(zhuǎn)換夏令時(shí)的問(wèn)題及解決方法
下面小編就為大家分享一篇基于java時(shí)區(qū)轉(zhuǎn)換夏令時(shí)的問(wèn)題及解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-11-11
在Java Spring框架中使用的設(shè)計(jì)模式有哪些
面試中常會(huì)被問(wèn)道Spring框架使用了哪些設(shè)計(jì)模式?關(guān)于這個(gè)問(wèn)題本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
Java集合List和Map互轉(zhuǎn)的方法總結(jié)
有時(shí)候我們需要將給定的List轉(zhuǎn)換為Map,或者M(jìn)ap轉(zhuǎn)換為L(zhǎng)ist,本文主要介紹了Java集合List和Map互轉(zhuǎn)的方法總結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
教你如何用Eclipse創(chuàng)建一個(gè)Maven項(xiàng)目
這篇文章主要介紹了教你如何用Eclipse創(chuàng)建一個(gè)Maven項(xiàng)目,文中有非常詳細(xì)的代碼示例,對(duì)正在入門(mén)Java的小伙伴們是非常有幫助的喲,需要的朋友可以參考下2021-05-05
使用Maven 搭建 Spring MVC 本地部署Tomcat的詳細(xì)教程
這篇文章主要介紹了使用Maven 搭建 Spring MVC 本地部署Tomcat,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08
Spring事務(wù)&Spring整合MyBatis的兩種方式
這篇文章主要介紹了Spring事務(wù)&Spring整合MyBatis的兩種方式,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-02-02
Java十大經(jīng)典排序算法的實(shí)現(xiàn)圖解
Java常見(jiàn)的排序算法有:插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序、基數(shù)排序等。本文詳解介紹Java十大十大經(jīng)典排序算法的實(shí)現(xiàn)以及圖解,需要的可以參考一下2022-03-03
AsyncHttpClient exception異常源碼流程解析
這篇文章主要為大家介紹了AsyncHttpClient的exception源碼流程解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12

