91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java怎么利用數組實現棧

發布時間:2021-09-14 21:31:48 來源:億速云 閱讀:136 作者:chen 欄目:編程語言

本篇內容介紹了“Java怎么利用數組實現棧”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

棧介紹

棧是一個先入后出的有序列表。

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

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

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

分析

使用數組來模擬棧的實現,首先考慮到數組的長度是固定的,所以使用棧就必須給一個特定的長度,即最大長度MaxSize。自定義一個棧頂指針, 初始化數據為-1,因為數組的索引值是從0開始的,為了不引起沖突,從-1開始。

棧為空:當top=-1時,即等于初始化數據,沒有任何元素存在數組中,則說明棧為空。

棧滿:隨著添加元素,棧頂指針將會往后移動,但是要考慮到數組的長度是固定的,就存在一個滿的情況。判斷條件是當top=MaxSize-1時,棧就滿了。比如定義3個大小的數組,放入一個數據1,top從-1變為0,再放入一個數據2,top從0變成1,再放入一個數據3,top從1變成2.這時候數組已經滿了,判斷條件即為top =MaxSize,為棧滿。

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

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

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

代碼實現

package cn.mrlij.stack; import java.util.Arrays;import java.util.Scanner; /** * 使用數組實現棧 *  * @author dreamer * */public class ArrayStackDemo { public static void main(String[] args) { // 測試 ArrayStack a = new ArrayStack(5); boolean flag = true;// 用于判斷循環結束的標志 Scanner sc = new Scanner(System.in); String key = "";// 用于接受菜單的選項 while (flag) { System.out.println("show:顯示棧"); System.out.println("exit:退出程序"); System.out.println("push:進棧"); System.out.println("pop:出棧"); key = sc.nextLine(); switch (key) { case "show": a.show(); break; case "exit": flag = false; System.out.println("程序結束!"); break;  case "push":  System.out.println("請輸入要進棧的數據:"); 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;// 定義數組的最大長度 private int[] arr;// 定義數組,數據就放在該數組 private int top = -1;// 定義棧頂,初始化數據為-1  public ArrayStack(int maxSize) { this.MaxSize = maxSize; arr = new int[MaxSize]; }  // 判斷數組是否為空 public boolean isEmpty() {  return top == -1; }  // 判斷數組是否滿了 public boolean isFull() { System.out.println("棧頂:" + top + "最大長度:" + MaxSize); return top == MaxSize - 1; }  // 進棧 public void push(int val) { // 先判斷棧是否滿了,滿了就不能添加進去 if (isFull()) { System.out.println("棧已經滿了~~"); 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("沒有數據"); return; } for (int i = top; i >= 0; i--) { System.out.print(arr[i] + "\t"); } System.out.println(); } }

“Java怎么利用數組實現棧”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阜康市| 新津县| 新闻| 工布江达县| 东方市| 成安县| 平江县| 宁海县| 廉江市| 石柱| 和龙市| 阿拉尔市| 固阳县| 桦南县| 湘潭市| 开封市| 凌云县| 公安县| 武城县| 乌海市| 泊头市| 河曲县| 南投县| 弥渡县| 万州区| 奉新县| 沿河| 崇信县| 隆回县| 萝北县| 漾濞| 永州市| 齐齐哈尔市| 镇巴县| 广宗县| 东乡族自治县| 开平市| 高碑店市| 西平县| 平江县| 柳江县|