成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java編程內功-數據結構與算法「棧(Stack)」

開發 后端 算法
棧是限制線性表中元素的插入和刪除只能在線性表的同一端進行的一種特殊線性表.允許插入和刪除的一端,為變化的一端,稱為棧頂(Top),另一端為固定的一端,稱為棧底(Bottom).

[[387145]]

 基本介紹

1. 棧是一個先入后出(FILO First In Last Out)的有序列表

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

3.根據棧的定義可知,最先放入棧中元素在棧底,最后放入的元素在棧頂,而刪除元素剛好相反,最后放入的元素最先刪除,最先放入的元素最后刪除.

棧的應用場景

1.子程序的調用:在調往子程序前,會先將下個指令的地址存到棧中,直到子程序執行完后再將地址取出,以回到原來的程序.

2.處理遞歸調用:和子程序的調用類似,只是除了儲存下一個指令的地址外,也將參數\區域變量等數據存入堆棧中.

3.表達式轉換(中綴表達式轉后綴表達式)與求值(實際解決).

4.二叉樹的遍歷.

5.圖形的深度優先(depth-first)搜索算法.

棧結構實現案例

  1. package com.structures.stack; 
  2.  
  3. import java.util.Scanner; 
  4.  
  5. public class ArrayStackDemo { 
  6.     public static void main(String[] args) { 
  7.         ArrayStack stack = new ArrayStack(4); 
  8.         String key = ""
  9.         boolean loop = true
  10.         Scanner scanner = new Scanner(System.in); 
  11.         while (loop) { 
  12.             System.out.println("show:顯示棧"); 
  13.             System.out.println("exit:退出程序"); 
  14.             System.out.println("push:添加數據到棧(入棧)"); 
  15.             System.out.println("pop:從棧取出數據(出棧)"); 
  16.             key = scanner.next(); 
  17.             switch (key) { 
  18.                 case "show"
  19.                     stack.list(); 
  20.                     break; 
  21.                 case "push"
  22.                     System.out.println("請輸入一個數"); 
  23.                     int value = scanner.nextInt(); 
  24.                     stack.push(value); 
  25.                     break; 
  26.                 case "pop"
  27.                     try { 
  28.                         int res = stack.pop(); 
  29.                         System.out.println("出棧的數據%d\n" + res); 
  30.                     } catch (Exception e) { 
  31.                         System.out.println(e.getMessage()); 
  32.                     } 
  33.                     break; 
  34.                 case "exit"
  35.                     scanner.close(); 
  36.                     loop = false
  37.                     break; 
  38.             } 
  39.         } 
  40.         System.out.println("程序退出"); 
  41.     } 
  42.  
  43. //定義一個類表示棧結構 
  44. class ArrayStack { 
  45.     private int maxSize;//棧的大小 
  46.     private int[] stack;//數組模擬棧,數據就放入該數組 
  47.     private int top = -1;//top表示棧頂,初始化-1 
  48.  
  49.     public ArrayStack(int maxSize) { 
  50.         this.maxSize = maxSize; 
  51.         stack = new int[this.maxSize]; 
  52.     } 
  53.  
  54.     //判斷是否棧滿 
  55.     public boolean isFull() { 
  56.         return top == maxSize - 1; 
  57.     } 
  58.  
  59.     //判斷是否棧空 
  60.     public boolean isEmpty() { 
  61.         return top == -1; 
  62.     } 
  63.  
  64.     //入棧 
  65.     public void push(int value) { 
  66.         if (isFull()) { 
  67.             System.out.println("棧滿"); 
  68.             return
  69.         } 
  70.         top++; 
  71.         stack[top] = value; 
  72.     } 
  73.  
  74.     //出棧 
  75.     public int pop() { 
  76.         if (isEmpty()) { 
  77.             throw new RuntimeException("棧空"); 
  78.         } 
  79.         int value = stack[top]; 
  80.         top--; 
  81.         return value; 
  82.     } 
  83.  
  84.     //顯示棧的情況[遍歷棧] 
  85.     public void list() { 
  86.         if (isEmpty()) { 
  87.             System.out.println("棧空,沒有數據~~"); 
  88.             return
  89.         } 
  90.         for (int i = top; i >= 0; i--) { 
  91.             System.out.printf("stack[%d]=%d\n", i, stack[i]); 
  92.         } 
  93.     } 
  94.  

 使用棧完成表達式的計算(中綴表達式)

準備兩個棧,數字棧和符號棧.

1.通過一個index值(索引),來遍歷表達式.

2.如果發現是一個數字就直接入數字棧.

3.如果是一個符號,分情況考慮如果當前符號棧為空,就直接入站.如果符號棧有操作符,就進行比較.

  • 如果當前操作符的優先級小于或者等于棧中的操作符,就需要從數棧中pop兩個數,再從符號棧中pop出一個字符,進行運算,將得到結果入數棧,然后當前操作符入符號棧.
  • 如果當前的操作符的優先級大于棧中的操作符,就直接入棧.

4.當表達式掃描完畢,就順序地從數棧和符號棧中pop出相應的數和符號,并運行.

5.最后在數字棧只有一個數字,就是表達式的結果.

  1. package com.structures.stack; 
  2.  
  3. public class Calculator { 
  4.     public static void main(String[] args) { 
  5.         //表達式 
  6.         String expression = "700+2*6-2"
  7.         //數棧 
  8.         ArrayStack2 numStack = new ArrayStack2(10); 
  9.         //符號棧 
  10.         ArrayStack2 operStack = new ArrayStack2(10); 
  11.         int index = 0;//用于掃描 
  12.         int num1 = 0; 
  13.         int num2 = 0; 
  14.         int oper = 0; 
  15.         int res = 0; 
  16.         char ch = ' ';//將每次掃描得到的char保存到ch 
  17.         String keepNum = "";//用于拼接多位數 
  18.         while (true) { 
  19.             ch = expression.substring(indexindex + 1).charAt(0); 
  20.             //如果是運算符 
  21.             if (operStack.isOper(ch)) { 
  22.                 //如果為空 
  23.                 if (operStack.isEmpty()) { 
  24.                     operStack.push(ch); 
  25.                 } else { 
  26.                     if (operStack.priority(ch) <= operStack.priority(operStack.peek())) { 
  27.                         num1 = numStack.pop(); 
  28.                         num2 = numStack.pop(); 
  29.                         oper = operStack.pop(); 
  30.                         res = numStack.cal(num1, num2, oper); 
  31.                         //把運算的結果入數棧,當前符號入符號棧 
  32.                         numStack.push(res); 
  33.                         operStack.push(ch); 
  34.                     } else { 
  35.                         operStack.push(ch); 
  36.                     } 
  37.                 } 
  38.             } else { 
  39.                 //當處理多位數時,不能立即入棧. 
  40.                 keepNum += ch; 
  41.                 //如果ch是expression的最后一位 
  42.                 if (index == expression.length() - 1) { 
  43.                     numStack.push(Integer.parseInt(keepNum)); 
  44.                 } else { 
  45.                     if (operStack.isOper(expression.substring(index + 1, index + 2).charAt(0))) { 
  46.                         numStack.push(Integer.parseInt(keepNum)); 
  47.                         keepNum = ""
  48.                     } 
  49.                 } 
  50.             } 
  51.             index++; 
  52.             //掃遍到最后就退出 
  53.             if (index >= expression.length()) { 
  54.                 break; 
  55.             } 
  56.         } 
  57.         while (true) { 
  58.             if (operStack.isEmpty()) { 
  59.                 break; 
  60.             } 
  61.             num1 = numStack.pop(); 
  62.             num2 = numStack.pop(); 
  63.             oper = operStack.pop(); 
  64.             res = numStack.cal(num1, num2, oper); 
  65.             numStack.push(res); 
  66.         } 
  67.         System.out.printf("表達式%s=%d\n", expression, numStack.pop()); 
  68.  
  69.     } 
  70.  
  71. class ArrayStack2 { 
  72.     private int maxSize;//棧的大小 
  73.     private int[] stack;//數組模擬棧,數據就放入該數組 
  74.     private int top = -1;//top表示棧頂,初始化-1 
  75.  
  76.     public ArrayStack2(int maxSize) { 
  77.         this.maxSize = maxSize; 
  78.         stack = new int[this.maxSize]; 
  79.     } 
  80.  
  81.     //返回當前棧頂的值,不是pop 
  82.     public int peek() { 
  83.         return stack[top]; 
  84.     } 
  85.  
  86.     //判斷是否棧滿 
  87.     public boolean isFull() { 
  88.         return top == maxSize - 1; 
  89.     } 
  90.  
  91.     //判斷是否棧空 
  92.     public boolean isEmpty() { 
  93.         return top == -1; 
  94.     } 
  95.  
  96.     //入棧 
  97.     public void push(int value) { 
  98.         if (isFull()) { 
  99.             System.out.println("棧滿"); 
  100.             return
  101.         } 
  102.         top++; 
  103.         stack[top] = value; 
  104.     } 
  105.  
  106.     //出棧 
  107.     public int pop() { 
  108.         if (isEmpty()) { 
  109.             throw new RuntimeException("棧空"); 
  110.         } 
  111.         int value = stack[top]; 
  112.         top--; 
  113.         return value; 
  114.     } 
  115.  
  116.     //顯示棧的情況[遍歷棧] 
  117.     public void list() { 
  118.         if (isEmpty()) { 
  119.             System.out.println("棧空,沒有數據~~"); 
  120.             return
  121.         } 
  122.         for (int i = top; i >= 0; i--) { 
  123.             System.out.printf("stack[%d]=%d\n", i, stack[i]); 
  124.         } 
  125.     } 
  126.  
  127.     //返回運算符的優先級,數字越大則優先級越高. 
  128.     //假定目前操作符只有 +  - * / 
  129.     public int priority(int oper) { 
  130.         if (oper == '*' || oper == '/') { 
  131.             return 1; 
  132.         } else if (oper == '+' || oper == '-') { 
  133.             return 0; 
  134.         } else { 
  135.             return -1; 
  136.         } 
  137.     } 
  138.  
  139.     //判斷是不是一個運算符 
  140.     public boolean isOper(char val) { 
  141.         return val == '+' || val == '-' || val == '*' || val == '/'
  142.     } 
  143.  
  144.     //計算方法 
  145.     public int cal(int num1, int num2, int oper) { 
  146.         int res = 0; 
  147.         switch (oper) { 
  148.             case '+'
  149.                 res = num1 + num2; 
  150.                 break; 
  151.             case '-'
  152.                 res = num2 - num1;//注意順序 
  153.                 break; 
  154.             case '*'
  155.                 res = num1 * num2; 
  156.                 break; 
  157.             case '/'
  158.                 res = num2 / num1;//注意順序 
  159.                 break; 
  160.         } 
  161.         return res; 
  162.     } 

 【編輯推薦】

 

責任編輯:姜華 來源: 今日頭條
相關推薦

2021-05-12 09:07:09

Java數據結構算法

2021-03-09 06:30:32

JAVA數據結構算法

2021-03-18 08:44:20

Java數據結構算法

2021-04-13 09:37:41

Java數據結構算法

2021-03-23 08:33:22

Java數據結構算法

2021-03-26 08:40:28

Java數據結構算法

2021-03-08 06:28:57

JAVA數據結構與算法稀疏數組

2021-03-10 08:42:19

Java數據結構算法

2021-03-17 09:27:36

Java數據結構算法

2021-04-15 09:36:44

Java數據結構算法

2021-04-07 09:26:37

Java數據結構算法

2021-04-16 09:40:52

Java數據結構算法

2021-03-14 08:27:40

Java數據結構算法

2021-04-22 10:07:45

Java數據結構算法

2021-05-13 07:34:56

Java數據結構算法

2021-04-23 09:12:09

Java數據結構算法

2021-03-11 08:53:20

Java數據結構算法

2021-03-24 10:41:04

Java數據結構算法

2021-05-08 08:28:38

Java數據結構算法

2021-04-01 10:34:18

Java編程數據結構算法
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: www久久 | 欧美一级久久久猛烈a大片 日韩av免费在线观看 | 久久久久久久久久久久久91 | 99精品99| 黄色国产在线视频 | 美女黄网站视频免费 | 欧美一区二区三区免费在线观看 | 欧美啊v在线观看 | 一区二区三区四区在线 | 青青草原精品99久久精品66 | 日本黄视频在线观看 | 久久福利电影 | 妞干网福利视频 | 亚洲国产aⅴ成人精品无吗 国产精品永久在线观看 | 亚洲精品久久久一区二区三区 | 国产aaaaav久久久一区二区 | 天天射天天操天天干 | 久草网址 | 天天干天天插天天 | 91亚洲国产成人久久精品网站 | 91久久国产综合久久91精品网站 | 中文字幕av在线 | 日本黄色大片免费 | 成年人在线观看 | 日本不卡一区二区三区 | 日日摸日日碰夜夜爽亚洲精品蜜乳 | 国产永久免费 | 九九免费在线视频 | 国产激情91久久精品导航 | 欧美黄色一区 | 97人人超碰 | 欧美一区二区三区在线观看视频 | 日韩一区二区在线视频 | 国产精品久久亚洲 | 精品欧美一区二区三区久久久 | 日韩精品在线播放 | 成人精品国产免费网站 | av在线免费观看网址 | 色在线免费视频 | 男女污污网站 | 精品欧美一区免费观看α√ |