国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java數據結構與算法之棧(動力節點Java學院整理)

Java數據結構與算法之棧(動力節點Java學院整理)

2020-09-10 13:47動力節點 Java教程

這篇文章主要介紹了Java數據結構與算法之棧,棧是先進后出的數據的結構,本文通過文字說明與實例代碼相結合的形式給大家介紹的非常詳細,需要的朋友跟著小編一起學習吧

stack,中文翻譯為堆,其實指的是棧,heap,堆。這里講的是數據結構的棧,不是內存分配里面的堆和棧。

棧是先進后出的數據的結構,好比你碟子一個一個堆起來,最后放的那個是堆在最上面的。

隊列就是排隊買蘋果,先去的那個可以先買。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
public class Stack {
   private int array[];
   private int max;
   private int top;
   public Stack(int max){
     this.max = max;
     array = new int[max];
     top = 0;
   }
   public void push(int value){
     if(isFull()){
       System.out.println("full,can not insert");
       return;
     }
     array[top++]=value;
   }
   public int pop(){
     return array[--top];
   }
   public boolean isEmpty(){
     if(top == 0){
       return true;
     }
     return false;
   }
   public boolean isFull(){
     if(top == max ){
       return true;
     }
     return false;
   }
   public void display(){
     while(!isEmpty()){
       System.out.println(pop());
     }
   }
   public static void main(String[] args) {
     Stack s = new Stack(5);
     s.push(1);
     s.push(3);
     s.push(5);
     s.push(5);
     s.push(5);
     s.display();
   }
 }

其實還是覺得設置top為-1好計算一點,記住這里的i++和++i,如果i=1,那么array[i++]=2,指的是array[1]=2,下次用到i的時候i的值才會變2,而++i就是直接使用i=2。

top指向0,因為每次都push一個元素加一,那么添加到最后一個元素的時候top=max。由于先進后出,那么先出的是最后進的,剛剛為top-1所在的位置。

正確輸出:

 5 
 5 
 5 
 3 
 1 

一、棧的使用——單詞逆序。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public String reverse(String in){
    String out="";
    for (int i = 0; i < in.length(); i++) {
      char c = in.charAt(i);
      push(c);
    }
    while(!isEmpty()){
      out+=pop();
    }
    return out;
  }
  public static void main(String[] args) {
    Scanner s = new Scanner(System.in);
    String string = s.nextLine();
    Stack st = new Stack(string.length());
    System.out.println(st.reverse(string));     
  }

將Stack的數組類型改為char即可。

讀取輸入也可以用IO讀取。

?
1
2
3
4
5
6
7
8
9
10
11
12
public static void main(String[] args) {
  InputStreamReader is = new InputStreamReader(System.in);
  BufferedReader b = new BufferedReader(is);
  String string="";
  try {
    string = b.readLine();
  } catch (IOException e) {
    e.printStackTrace();
  }
  Stack st = new Stack(string.length());
  System.out.println(st.reverse(string));
}

二、棧的使用——分隔符匹配。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
public int charat(char c){
  for (int i = 0; i < array.length; i++) {
    if(c == array[i])
      return i;
  }
  return array.length;
}
public void match(String in){
  String out="";
  for (int i = 0; i < in.length(); i++) {
    char c = in.charAt(i);
    if(c == '{' || c == '(' || c == '[' ){
      push(c);
    }
    if(c == '}' || c == ')' || c == ']'){
      char temp = pop();
     if(c == '}' && temp != '{'|| c == ')' && temp != '('|| c == ']' && temp != ']'){
        System.out.println("can not match in "+i);
      }
    }
  }
  while(!isEmpty()){
    char c = pop();
    if(c == '{'){
      System.out.println("insert } to match "+charat(c));
    }
    if(c == '[' ){
      System.out.println("insert ] to match "+charat(c));
    }
    if(c == '(' ){
      System.out.println("insert ) to match "+charat(c));
    }
  }
}
public static void main(String[] args) {
  Scanner s = new Scanner(System.in);
  String string = s.nextLine();
  Stack st = new Stack(string.length());
  st.match(string);
}
result:
klsjdf(klj{lkjjsdf{)
can not match in 19
insert } to match 1
insert ) to match 0

將({[先壓入棧,一旦遇到)}]便與彈出的元素比較,若吻合,則匹配。如果一直沒有)}],最后便會彈出棧的左符號,提示是在具體哪個位置,缺少的具體的右符號類型。

這是可以用棧來實現的工具。

棧中數據入棧和出棧的時間復雜度為常數O(1),因為與數據個數無關,直接壓入彈出,操作時間短,優勢便在這里,如果現實生活的使用只需用到先進后出的順序而且只用到進出數據的比較,那就可以使用棧了。

以上所述是小編給大家介紹的Java數據結構與算法之棧(動力節點Java學院整理),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美日韩中文字幕在线 | 亚洲精品在线播放视频 | 亚洲国产精品电影在线观看 | 中文字幕免费中文 | 美女久久| 国内自拍视频在线观看 | 精品国产乱码久久久久久久 | 免费成人在线网站 | 欧美一区二区三区在线 | 日韩中文字幕在线视频 | 激情久久久 | 精品视频久久 | 亚洲一区二区三区四区五区午夜 | 蜜臀精品 | 久久亚 | 国产日韩精品视频 | 国产一二在线 | 久久九九国产精品 | 波多野结衣一二三四区 | 免费观看黄色大片 | 美日韩一区 | 特级西西人体444www高清大胆 | 欧美黄页| 欧美一级欧美三级在线观看 | 日韩成人中文字幕 | 亚洲视频在线看 | 99爱在线观看 | 亚洲一区在线视频 | 国产有码| 欧美日韩电影一区 | 日本不卡在线观看 | 综合自拍偷拍 | 成人a在线视频免费观看 | 久久天天 | 亚洲一区精品在线 | 国产亚洲人成网站在线观看 | 国产精品一卡 | 国产精品影视 | 看国产到性色 | 免费久久99精品国产婷婷六月 | 毛片色|