У цьому прикладі ми навчимося реалізовувати структуру даних стеку в Java.
Щоб зрозуміти цей приклад, ви повинні знати такі теми програмування Java:
- Клас стеку Java
- Java Generics
Приклад 1: Програма Java для реалізації Stack
// Stack implementation in Java class Stack ( // store elements of stack private int arr(); // represent top of stack private int top; // total capacity of the stack private int capacity; // Creating a stack Stack(int size) ( // initialize the array // initialize the stack variables arr = new int(size); capacity = size; top = -1; ) // push elements to the top of stack public void push(int x) ( if (isFull()) ( System.out.println("Stack OverFlow"); // terminates the program System.exit(1); ) // insert element on top of stack System.out.println("Inserting " + x); arr(++top) = x; ) // pop elements from top of stack public int pop() ( // if stack is empty // no element to pop if (isEmpty()) ( System.out.println("STACK EMPTY"); // terminates the program System.exit(1); ) // pop element from top of stack return arr(top--); ) // return size of the stack public int getSize() ( return top + 1; ) // check if the stack is empty public Boolean isEmpty() ( return top == -1; ) // check if the stack is full public Boolean isFull() ( return top == capacity - 1; ) // display elements of stack public void printStack() ( for (int i = 0; i <= top; i++) ( System.out.print(arr(i) + ", "); ) ) public static void main(String() args) ( Stack stack = new Stack(5); stack.push(1); stack.push(2); stack.push(3); System.out.print("Stack: "); stack.printStack(); // remove element from stack stack.pop(); System.out.println("After popping out"); stack.printStack(); ) )
Вихідні дані
Вставка 1 Вставка 2 Вставка 3 Стек: 1, 2, 3, після вискакування 1, 2,
У наведеному вище прикладі ми реалізували структуру даних стеку в Java.
Щоб дізнатися більше, відвідайте Структура даних стеку.
Приклад 2: Реалізуйте стек, використовуючи клас Stack
Java забезпечує вбудований Stack
клас, який можна використовувати для реалізації стека.
import java.util.Stack; class Main ( public static void main(String() args) ( // create an object of Stack class Stack animals= new Stack(); // push elements to top of stack animals.push("Dog"); animals.push("Horse"); animals.push("Cat"); System.out.println("Stack: " + animals); // pop element from top of stack animals.pop(); System.out.println("Stack after pop: " + animals); ) )
Вихідні дані
Стек: (Собака, Кінь, Кіт) Стек після попу: (Собака, Кінь)
У наведеному вище прикладі ми використовували Stack
клас для реалізації стека в Java. Ось,
- animals.push () - вставте елементи у верх стека
- animals.pop () - видалити елемент з верхньої частини стека
Зверніть увагу, ми використовували кутові дужки під час створення стека. Це означає, що стек є загальним типом.