第二に、スタック
1.スタックの定義:
スタック又叫LIFO(后进先出)表
:挿入と削除を1つの位置に制限するテーブルです。この位置は、スタックの最上位と呼ばれるテーブルの終わりです。
2.スタックの基本的な操作:
push(进栈)
pop(出栈)
コード例
package demo.test;
public class MyStack {
//栈的底层使用数组存储元素
int[] elements;
public MyStack() {
elements = new int[0];
}
//压入元素
public void push(int element) {
int[] newArr = new int[elements.length+1];
//把原数组元素复制到新数组中
for(int i=0;i<elements.length;i++) {
newArr[i] = elements[i];
}
//把添加的元素放到新数组中
newArr[elements.length] = element;
//替换
elements = newArr;
}
//取出栈顶元素
public int pop() {
if (elements.length==0) {
throw new RuntimeException("stack is empty");
}
int element = elements[elements.length-1];
//创建新数组
int[] newArr = new int[elements.length-1];
//取出后放入新数组
for (int i=0;i<elements.length-1;i++) {
newArr[i] = elements[i];
}
//替换数组
elements = newArr;
//返回栈顶元素
return element;
}
//查看栈顶元素
public int peek() {
if (elements.length==0) {
throw new RuntimeException("stack is empty");
}
return elements[elements.length-1];
}
//判断栈顶元素是否为空
public boolean isEmpty() {
return elements.length == 0;
}
}
テストコード:
package demo.test1;
import demo.test.MyStack;
public class TestMyStack {
public static void main(String[] args) {
//创建一个栈
MyStack ms = new MyStack();
//压入数据
ms.push(9);
ms.push(8);
ms.push(7);
//取出栈顶元素
System.out.println(ms.pop());
System.out.println(ms.pop());
System.out.println(ms.pop());
//查看栈顶元素
//System.out.println(ms.peek());
System.out.println(ms.isEmpty());
}
}
3.スタックの実現:
- チェーン構造を使用する
- 配列を使用する
4.スタックアプリケーション
- バランスの取れたシンボル:大規模なプログラムでシンボルが不足しているために発生するエラーを検出するために使用されます
- 後置式:スタックを介した6523 + + 3 + 8 * *としての
后缀
or逆波兰
式表記、優先ルールを知る必要はありません。 - 中置から接尾辞への変換:スタックを使用して、標準形式の式(または中置式と呼ばれる)を、中置式a + b * c +(d * e + f)* gなどの後置式に変換します。 abc * + de * f + g * +に変換
- メソッド呼び出し:
テーブルを再帰的に出力しない
public static <AnyType> void printList(Iterator<AnyType> itr) {
while(true) {
if (!itr.hasNext())
return;
System.out.println(itr.next());
}
}