自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Java編程內(nèi)功-數(shù)據(jù)結(jié)構(gòu)與算法「棧(Stack)」

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

[[387145]]

 基本介紹

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

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

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

棧的應(yīng)用場(chǎng)景

1.子程序的調(diào)用:在調(diào)往子程序前,會(huì)先將下個(gè)指令的地址存到棧中,直到子程序執(zhí)行完后再將地址取出,以回到原來的程序.

2.處理遞歸調(diào)用:和子程序的調(diào)用類似,只是除了儲(chǔ)存下一個(gè)指令的地址外,也將參數(shù)\區(qū)域變量等數(shù)據(jù)存入堆棧中.

3.表達(dá)式轉(zhuǎn)換(中綴表達(dá)式轉(zhuǎn)后綴表達(dá)式)與求值(實(shí)際解決).

4.二叉樹的遍歷.

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

棧結(jié)構(gòu)實(shí)現(xiàn)案例

  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:添加數(shù)據(jù)到棧(入棧)"); 
  15.             System.out.println("pop:從棧取出數(shù)據(jù)(出棧)"); 
  16.             key = scanner.next(); 
  17.             switch (key) { 
  18.                 case "show"
  19.                     stack.list(); 
  20.                     break; 
  21.                 case "push"
  22.                     System.out.println("請(qǐng)輸入一個(gè)數(shù)"); 
  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("出棧的數(shù)據(jù)%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. //定義一個(gè)類表示棧結(jié)構(gòu) 
  44. class ArrayStack { 
  45.     private int maxSize;//棧的大小 
  46.     private int[] stack;//數(shù)組模擬棧,數(shù)據(jù)就放入該數(shù)組 
  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("???沒有數(shù)據(jù)~~"); 
  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.  

 使用棧完成表達(dá)式的計(jì)算(中綴表達(dá)式)

準(zhǔn)備兩個(gè)棧,數(shù)字棧和符號(hào)棧.

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

2.如果發(fā)現(xiàn)是一個(gè)數(shù)字就直接入數(shù)字棧.

3.如果是一個(gè)符號(hào),分情況考慮如果當(dāng)前符號(hào)棧為空,就直接入站.如果符號(hào)棧有操作符,就進(jìn)行比較.

  • 如果當(dāng)前操作符的優(yōu)先級(jí)小于或者等于棧中的操作符,就需要從數(shù)棧中pop兩個(gè)數(shù),再?gòu)姆?hào)棧中pop出一個(gè)字符,進(jìn)行運(yùn)算,將得到結(jié)果入數(shù)棧,然后當(dāng)前操作符入符號(hào)棧.
  • 如果當(dāng)前的操作符的優(yōu)先級(jí)大于棧中的操作符,就直接入棧.

4.當(dāng)表達(dá)式掃描完畢,就順序地從數(shù)棧和符號(hào)棧中pop出相應(yīng)的數(shù)和符號(hào),并運(yùn)行.

5.最后在數(shù)字棧只有一個(gè)數(shù)字,就是表達(dá)式的結(jié)果.

  1. package com.structures.stack; 
  2.  
  3. public class Calculator { 
  4.     public static void main(String[] args) { 
  5.         //表達(dá)式 
  6.         String expression = "700+2*6-2"
  7.         //數(shù)棧 
  8.         ArrayStack2 numStack = new ArrayStack2(10); 
  9.         //符號(hào)棧 
  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 = "";//用于拼接多位數(shù) 
  18.         while (true) { 
  19.             ch = expression.substring(indexindex + 1).charAt(0); 
  20.             //如果是運(yùn)算符 
  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.                         //把運(yùn)算的結(jié)果入數(shù)棧,當(dāng)前符號(hào)入符號(hào)棧 
  32.                         numStack.push(res); 
  33.                         operStack.push(ch); 
  34.                     } else { 
  35.                         operStack.push(ch); 
  36.                     } 
  37.                 } 
  38.             } else { 
  39.                 //當(dāng)處理多位數(shù)時(shí),不能立即入棧. 
  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("表達(dá)式%s=%d\n", expression, numStack.pop()); 
  68.  
  69.     } 
  70.  
  71. class ArrayStack2 { 
  72.     private int maxSize;//棧的大小 
  73.     private int[] stack;//數(shù)組模擬棧,數(shù)據(jù)就放入該數(shù)組 
  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.     //返回當(dāng)前棧頂?shù)闹?不是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("???quot;); 
  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("???沒有數(shù)據(jù)~~"); 
  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.     //返回運(yùn)算符的優(yōu)先級(jí),數(shù)字越大則優(yōu)先級(jí)越高. 
  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.     //判斷是不是一個(gè)運(yùn)算符 
  140.     public boolean isOper(char val) { 
  141.         return val == '+' || val == '-' || val == '*' || val == '/'
  142.     } 
  143.  
  144.     //計(jì)算方法 
  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.     } 

 【編輯推薦】

 

責(zé)任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2021-04-13 09:37:41

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-09 06:30:32

JAVA數(shù)據(jù)結(jié)構(gòu)算法

2021-03-18 08:44:20

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-05-12 09:07:09

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-17 09:27:36

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-10 08:42:19

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-08 06:28:57

JAVA數(shù)據(jù)結(jié)構(gòu)與算法稀疏數(shù)組

2021-03-23 08:33:22

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-26 08:40:28

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-04-15 09:36:44

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-04-22 10:07:45

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-14 08:27:40

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-04-16 09:40:52

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-04-07 09:26:37

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-05-13 07:34:56

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-24 10:41:04

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-04-23 09:12:09

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-11 08:53:20

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-05-08 08:28:38

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-19 10:25:12

Java數(shù)據(jù)結(jié)構(gòu)算法
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)