亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

利用數(shù)組實(shí)現(xiàn)棧(Java實(shí)現(xiàn))

 更新時(shí)間:2019年09月25日 15:32:41   作者:dreamer_it  
這篇文章主要為大家詳細(xì)介紹了利用數(shù)組實(shí)現(xiàn)棧,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

棧介紹

棧是一個(gè)先入后出的有序列表。

棧是限制線性表中元素的插入和刪除只能在線性表中同一端進(jìn)行的一種特殊的線性表,允許插入和刪除的一端,為變化的一端,稱為棧頂,另一端為固定的一端,稱為棧底。

最先放入棧中的元素在棧底,最后放入的元素在棧頂。

最先出棧的元素在棧頂,最后出棧的元素在棧底。

分析

使用數(shù)組來模擬棧的實(shí)現(xiàn),首先考慮到數(shù)組的長(zhǎng)度是固定的,所以使用棧就必須給一個(gè)特定的長(zhǎng)度,即最大長(zhǎng)度MaxSize。自定義一個(gè)棧頂指針, 初始化數(shù)據(jù)為-1,因?yàn)閿?shù)組的索引值是從0開始的,為了不引起沖突,從-1開始。

棧為空:當(dāng)top=-1時(shí),即等于初始化數(shù)據(jù),沒有任何元素存在數(shù)組中,則說明棧為空。

棧滿:隨著添加元素,棧頂指針將會(huì)往后移動(dòng),但是要考慮到數(shù)組的長(zhǎng)度是固定的,就存在一個(gè)滿的情況。判斷條件是當(dāng)top=MaxSize-1時(shí),棧就滿了。比如定義3個(gè)大小的數(shù)組,放入一個(gè)數(shù)據(jù)1,top從-1變?yōu)?,再放入一個(gè)數(shù)據(jù)2,top從0變成1,再放入一個(gè)數(shù)據(jù)3,top從1變成2.這時(shí)候數(shù)組已經(jīng)滿了,判斷條件即為top =MaxSize,為棧滿。

進(jìn)棧:進(jìn)棧前先判斷棧是否滿了,否則不能進(jìn)棧。將top+1,在將數(shù)組索引為top的元素賦值為添加進(jìn)來的數(shù)據(jù)。

出棧:出棧前先判斷棧是否為空,否則不能出棧。如果不為空,先取棧頂?shù)脑?,即索引值為top的元素,然后在將top-1。

遍歷棧:遍歷時(shí)也要判斷棧中是否為空,遍歷數(shù)據(jù)也是從棧頂元素開始遍歷, 一直遍歷到棧底就結(jié)束了。

代碼實(shí)現(xiàn)

package cn.mrlij.stack;
 
import java.util.Arrays;
import java.util.Scanner;
 
/**
 * 使用數(shù)組實(shí)現(xiàn)棧
 * 
 * @author dreamer
 *
 */
public class ArrayStackDemo {
 public static void main(String[] args) {
 // 測(cè)試
 ArrayStack a = new ArrayStack(5);
 boolean flag = true;// 用于判斷循環(huán)結(jié)束的標(biāo)志
 Scanner sc = new Scanner(System.in);
 String key = "";// 用于接受菜單的選項(xiàng)
 while (flag) {
 System.out.println("show:顯示棧");
 System.out.println("exit:退出程序");
 System.out.println("push:進(jìn)棧");
 System.out.println("pop:出棧");
 key = sc.nextLine();
 switch (key) {
 case "show":
 a.show();
 break;
 case "exit":
 flag = false;
 System.out.println("程序結(jié)束!");
 break;
 
 case "push":
 
 System.out.println("請(qǐng)輸入要進(jìn)棧的數(shù)據(jù):");
 int val = sc.nextInt();
 a.push(val);
 
 break;
 case "pop":
 try {
 int pop = a.pop();
 System.out.println("出棧的值是:" + pop);
 } catch (Exception e) {
 // TODO: handle exception
 System.out.println(e.getMessage());
 }
 break;
 default:
 break;
 }
 
 }
 
 }
}
 
class ArrayStack {
 private int MaxSize;// 定義數(shù)組的最大長(zhǎng)度
 private int[] arr;// 定義數(shù)組,數(shù)據(jù)就放在該數(shù)組
 private int top = -1;// 定義棧頂,初始化數(shù)據(jù)為-1
 
 public ArrayStack(int maxSize) {
 this.MaxSize = maxSize;
 arr = new int[MaxSize];
 }
 
 // 判斷數(shù)組是否為空
 public boolean isEmpty() {
 
 return top == -1;
 }
 
 // 判斷數(shù)組是否滿了
 public boolean isFull() {
 System.out.println("棧頂:" + top + "最大長(zhǎng)度:" + MaxSize);
 return top == MaxSize - 1;
 }
 
 // 進(jìn)棧
 public void push(int val) {
 // 先判斷棧是否滿了,滿了就不能添加進(jìn)去
 if (isFull()) {
 System.out.println("棧已經(jīng)滿了~~");
 return;
 }
 top++;
 arr[top] = val;
 }
 
 // 出棧
 public int pop() {
 // 先判斷棧是否為空
 if (isEmpty()) {
 throw new RuntimeException("棧為空,無法出棧!");
 }
 int val = arr[top];
 top--;
 return val;
 }
 
 public void show() {
 if (isEmpty()) {
 System.out.println("沒有數(shù)據(jù)");
 return;
 }
 for (int i = top; i >= 0; i--) {
 System.out.print(arr[i] + "\t");
 }
 System.out.println();
 }
 
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 解決idea中debug工具欄消失后如何顯示的問題

    解決idea中debug工具欄消失后如何顯示的問題

    這篇文章主要介紹了解決idea中debug工具欄消失后如何顯示的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • Java多態(tài)的全面系統(tǒng)解析

    Java多態(tài)的全面系統(tǒng)解析

    多態(tài)就是指程序中定義的引用變量所指向的具體類型和通過該引用變量發(fā)出的方法調(diào)用在編程時(shí)并不確定,而是在程序運(yùn)行期間才確定,即一個(gè)引用變量到底會(huì)指向哪個(gè)類的實(shí)例對(duì)象,該引用變量發(fā)出的方法調(diào)用到底是哪個(gè)類中實(shí)現(xiàn)的方法,必須在由程序運(yùn)行期間才能決定
    2022-03-03
  • SpringBoot通過整合Dubbo解決@Reference注解問題

    SpringBoot通過整合Dubbo解決@Reference注解問題

    這篇文章主要介紹了SpringBoot通過整合Dubbo解決@Reference注解問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Spring boot的上傳圖片功能實(shí)例詳解

    Spring boot的上傳圖片功能實(shí)例詳解

    Spring Boot是由Pivotal團(tuán)隊(duì)提供的全新框架,其設(shè)計(jì)目的是用來簡(jiǎn)化新Spring應(yīng)用的初始搭建以及開發(fā)過程。這篇文章主要介紹了Spring boot 上傳圖片,需要的朋友可以參考下
    2018-03-03
  • SpringBoot中配置雙數(shù)據(jù)源的實(shí)現(xiàn)示例

    SpringBoot中配置雙數(shù)據(jù)源的實(shí)現(xiàn)示例

    在許多應(yīng)用程序中,可能會(huì)遇到需要連接多個(gè)數(shù)據(jù)庫(kù)的情況,本文主要介紹了SpringBoot中配置雙數(shù)據(jù)源的實(shí)現(xiàn)示例,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08
  • SpringBoot的三大開發(fā)工具小結(jié)

    SpringBoot的三大開發(fā)工具小結(jié)

    本文主要介紹了SpringBoot的三大開發(fā)工具,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-02-02
  • Java基于ShardingSphere實(shí)現(xiàn)分庫(kù)分表的實(shí)例詳解

    Java基于ShardingSphere實(shí)現(xiàn)分庫(kù)分表的實(shí)例詳解

    ShardingSphere?已于2020年4月16日成為?Apache?軟件基金會(huì)的頂級(jí)項(xiàng)目,?它們均提供標(biāo)準(zhǔn)化的數(shù)據(jù)水平擴(kuò)展、分布式事務(wù)和分布式治理等功能,可適用于如?Java?同構(gòu)、異構(gòu)語言、云原生等各種多樣化的應(yīng)用場(chǎng)景,對(duì)ShardingSphere分庫(kù)分表相關(guān)知識(shí)感興趣的朋友一起看看吧
    2022-03-03
  • Nacos后臺(tái)頻繁打印get changedGroupKeys:[]的問題及解決

    Nacos后臺(tái)頻繁打印get changedGroupKeys:[]的問題及解決

    這篇文章主要介紹了Nacos后臺(tái)頻繁打印get changedGroupKeys:[]的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • IntelliJ IDEA的數(shù)據(jù)庫(kù)管理工具實(shí)在太方便了(推薦)

    IntelliJ IDEA的數(shù)據(jù)庫(kù)管理工具實(shí)在太方便了(推薦)

    這篇文章主要介紹了IntelliJ IDEA的數(shù)據(jù)庫(kù)管理工具實(shí)在太方便了,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Springboot接入MyBatisPlus的實(shí)現(xiàn)

    Springboot接入MyBatisPlus的實(shí)現(xiàn)

    最近web端比較熱門的框架就是SpringBoot和Mybatis-Plus,這里簡(jiǎn)單總結(jié)集成用法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09

最新評(píng)論