国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

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-18 08:44:20

Java數據結構算法

2021-03-09 06:30:32

JAVA數據結構算法

2021-04-13 09:37:41

Java數據結構算法

2021-03-23 08:33:22

Java數據結構算法

2021-03-26 08:40:28

Java數據結構算法

2021-03-17 09:27:36

Java數據結構算法

2021-03-08 06:28:57

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

2021-03-10 08:42:19

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技術棧公眾號

日本h片久久| 亚洲制服欧美久久| 成人激情免费视频| 欧美亚洲另类在线| 久久精品30| www.精品在线| 亚洲精品第一页| 成人婷婷网色偷偷亚洲男人的天堂| 欧美日韩免费观看一区| 中文字幕欧美三区| 青草av在线| 国产精品久久久久久久久久久不卡| 玖玖视频精品| 日本二区视频| 色偷偷888欧美精品久久久| 婷婷综合久久| 91精品91久久久中77777老牛| 777久久久精品| 精品日产免费二区日产免费二区| 激情视频小说图片| 国内精品写真在线观看| 日韩欧美一区免费| 中文字幕欧美人妻精品一区| 亚洲成人精品影院| 国产福利片在线观看| 日韩毛片在线免费看| 午夜av区久久| 高清精品久久| 色噜噜一区二区| 黑人巨大精品欧美一区二区| 欧美高清一级片| 国产欧美综合一区| 欧美日韩不卡一区二区| 精品久久成人| 国产视频一区二区三区在线播放| 欧美丰满一区二区免费视频| 成人在线免费观看91| 青青在线视频观看| 日韩精品免费在线| 国产精品视频| 国模精品一区二区| 国产国语刺激对白av不卡| 久久久久高清精品| 亚洲一区二区小说| 少妇久久久久久被弄到高潮| 欧美刺激脚交jootjob| 亚洲日产国产精品| 国产天堂在线| 亚洲一区二区三区毛片| 亚洲国产精品尤物yw在线观看| 国内精品麻豆美女在线播放视频| 日本久久高清视频| 日韩av在线最新| 久久国产精品无码网站| 51漫画成人app入口| 日本一区二区在线| 91精品麻豆日日躁夜夜躁| 亚洲高清自拍| 国产在线视频资源| 99久久国产免费免费| 精品欧美激情精品一区| 成人毛片在线| 青檬在线电视剧在线观看| 国产精品福利在线| 亚洲视频免费在线| 亚州精品视频| 免费毛片aaaaaa| 国产精品揄拍一区二区| 亚洲一区二区三区免费视频| 国产精品亚洲二区| 最新二区三区av| 成人精品在线视频| 91国内精品野花午夜精品| 中文字幕乱码亚洲无线精品一区| 欧美孕妇性xxxⅹ精品hd| 51国偷自产一区二区三区| 色国产精品一区在线观看| 亚洲欧洲日本一区二区三区| 理论片午午伦夜理片在线播放| 欧美午夜欧美| 日韩国产精品亚洲а∨天堂免| 激情久久五月天| 亚洲一区av| 先锋影音成人资源| 成人h视频在线观看播放| 欧美性感一区二区三区| 日韩精品国产精品| 色豆豆成人网| 成视人a免费观看视频| 2014亚洲精品| 亚洲第一精品夜夜躁人人躁| 91亚洲精品久久久蜜桃网站| 国产99久久| av文字幕在线观看| 成人免费观看cn| 国产成人精品免费视频| 欧美视频在线播放| 国产精品123区| 色橹橹欧美在线观看视频高清 | 91视频免费播放| 久9久9色综合| 91网址在线观看| 116极品美女午夜一级| 国产精品色悠悠| 精品久久久久久久人人人人传媒| 91亚洲精品久久久蜜桃网站 | 中文字幕一区二区三区乱码在线| 久久综合成人| 黄视频网站在线观看| av污在线观看| 国产视频不卡| 日韩中文有码在线视频| 亚洲一区二区三区小说| 午夜在线观看免费一区| 国产精品久久久久久久久久辛辛| 亚洲成av人影片在线观看| 日本特级黄色大片| 国产精品av在线播放| 精品久久人人做人人爰| 国产精品免费看片| 新狼窝色av性久久久久久| 日本一区二区三区播放| 国产精品久久一区二区三区不卡 | 欧美网站免费观看| 91久久久精品| 中文字幕亚洲欧美一区二区三区 | 欧美日韩精品一区二区天天拍小说 | 欧美日韩国产在线观看网站| 天堂va在线| 爱草在线视频| 在线观看欧美亚洲| 国产91精品久久久久| 日韩西西人体444www| 亚洲欧洲韩国日本视频| 免费欧美在线视频| 国产日产一区 | 日本视频一区二区三区| 久操精品在线| 成人日韩在线| 韩国三级av在线免费观看| 久久久久久久午夜| 国产区二精品视| 午夜精品在线视频| 亚洲女人被黑人巨大进入| 色悠久久久久综合欧美99| 国产亚洲欧美一区在线观看| 免费永久网站黄欧美| 日韩欧美高清| 成人资源在线| 97精品国产综合久久久动漫日韩 | 欧美在线视频播放| 亚洲视频视频在线| 欧美日韩1234| 亚洲尤物在线视频观看| 成人av电影在线播放| 久久蜜桃精品| 国产精品久久占久久| 国产成人澳门| 国产人妖一区| 好久没做在线观看| 国产女人在线观看| 天天干夜夜干| 成年美女网站| 国产男女无遮挡| 91免费网站视频| 国产区二精品视| 成人在线免费观看视视频| 午夜精品在线视频| 久久国产精品影片| 自拍偷拍亚洲精品| 亚洲欧美综合图区| 亚洲国产第一页| 日韩免费看网站| 4438亚洲最大| 欧美色国产精品| 欧美日韩在线看| 一区二区三区四区在线免费观看| 国产拍揄自揄精品视频麻豆| 成人动漫av在线| 国产传媒久久文化传媒| 久久国产精品区| 奇米色777欧美一区二区| 亚洲精品影院在线观看| 亚洲天堂黄色| 亚洲美女黄色| 精品999日本| 欧美在线黄色| 亚洲欧美一区在线| 欧美激情自拍| 欧美三区不卡| 亚洲精品人人| 一区二区日本视频| 久久av在线| 日韩国产欧美三级| 免费久久99精品国产自在现线| av成人天堂| 蜜臀av一区二区在线免费观看 | 国产成人免费视频网站高清观看视频| 精品一区二区三区在线播放视频| 蜜桃av噜噜一区二区三区小说|