定義
棧是一種線性結構,棧是一種後進先出的資料結構
last in first out(LIFO)
圖解示例
(來源于網絡)

代碼實作
這裡使用之前寫的動态數組類
Stack接口
/**
* @author: curry
* @Date: 2018/8/7
*/
public interface Stack<E> {
/**
* 擷取棧中元素數量
*
* @return
*/
int getSize();
/**
* 判斷是否為空
*
* @return
*/
boolean isEmpty();
/**
* 存放元素
*
* @param e
*/
void push(E e);
/**
* 出棧
*
* @return
*/
E pop();
/**
* 擷取棧頂的值
*
* @return
*/
E peek();
}
ArrayStack
/**
* @author: curry
* @Date: 2018/8/7
*/
public class ArrayStack<E> implements Stack<E> {
private Array<E> array;
public ArrayStack(int capacity) {
array = new Array<>(capacity);
}
public ArrayStack() {
array = new Array<>();
}
@Override
public int getSize() {
return array.getSize();
}
@Override
public boolean isEmpty() {
return array.isEmpty();
}
@Override
public void push(E e) {
array.addLast(e);
}
@Override
public E pop() {
return array.removeLast();
}
@Override
public E peek() {
return array.getLast();
}
@Override
public String toString(){
StringBuilder res = new StringBuilder();
res.append("Stack: ");
res.append('[');
for (int i = 0; i <array.getSize() ; i++) {
res.append(array.get(i));
if(i!= array.getSize()-1){
res.append(",");
}
}
res.append("] top" );
return res.toString();
}
}
練習題
這個是LeetCode上的20題
給定一個隻包括 '(',')','{','}','[',']' 的字元串,判斷字元串是否有效。
有效字元串需滿足:
左括号必須用相同類型的右括号閉合。
左括号必須以正确的順序閉合。
注意空字元串可被認為是有效字元串。
示例 1:
輸入: "()"
輸出: true
示例 2:
輸入: "()[]{}"
示例 3:
輸入: "(]"
輸出: false
示例 4:
輸入: "([)]"
示例 5:
輸入: "{[]}"
import java.util.Stack;
/**
* @author: curry
* @Date: 2018/8/11
*/
public class Solution {
public boolean isValid(String s) {
Stack<Character> stack = new Stack<>();
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
if (c == '(' || c == '{' || c == '[') {
stack.push(c);
} else {
if (stack.isEmpty()) {
return false;
}
char topChar = stack.pop();
if (c == ')' && topChar != '(') {
return false;
}
if (c == '}' && topChar != '{') {
return false;
}
if (c == ']' && topChar != '[') {
return false;
}
}
}
return stack.isEmpty();
}
}
學習不是要麼0分,要麼100分的。80分是收獲;60分是收獲;20分也是收獲。有收獲最重要。但是因為着眼于自己的不完美,最終放棄了,那就是徹底的0分了。