


The definition of the php stack, the push and pop methods, and the complete implementation example of the calculator
The stack is a type of linear table. Its characteristic is last in first out. It can be understood that the stack is like a box for storing things. The first things are put in at the bottom, and the last things are put in. It's on the upper level, because the things on the upper level hold down the things on the bottom level. If the things on the lower level want to get out, they have to remove the things on the upper level first.
Introduction code:
data class: It is the class that stores data. () is what is to be put into the stack
stack class: It is the class of the stack, and the entire stack is in this class
Main method:
Enter Stack push_stack($data) detects whether the stack is full, and if not, pushes data onto the stack.
Pop_stack($data) detects whether the stack is empty. If it is not empty, it can be popped.
Read the top element of the stack top_stack(). If the stack is not empty, return the data at the top of the current stack.
The following is the code:
<?php /** * Author Been **/ class data{ //数据 private $data; public function construct($data){ $this->data=$data; echo $data.":哥入栈了!<br>"; } public function getData(){ return $this->data; } public function destruct(){ echo $this->data.":哥走了!<br>"; } } class stack{ private $size; private $top; private $stack=array(); public function construct($size){ $this->Init_Stack($size); } //初始化栈 public function Init_Stack($size){ $this->size=$size; $this->top=-1; } //判断栈是否为空 public function Empty_Stack(){ if($this->top==-1)return 1; else return 0; } //判断栈是否已满 public function Full_Stack(){ if($this->top<$this->size-1)return 0; else return 1; } //入栈 public function Push_Stack($data){ if($this->Full_Stack())echo "栈满了<br />"; else $this->stack[++$this->top]=new data($data); } //出栈 public function Pop_Stack(){ if($this->Empty_Stack())echo "栈空着呢<br />"; else unset($this->stack[$this->top--]); } //读取栈顶元素 public function Top_Stack(){ return $this->Empty_Stack()?"栈空无数据!":$this->stack[$this->top]->getData(); } } $stack=new stack(4); $stack->Pop_Stack(); $stack->Push_Stack("aa"); $stack->Push_Stack("aa1"); $stack->Pop_Stack("aa1"); $stack->Push_Stack("aa2"); $stack->Push_Stack("aa3"); $stack->Push_Stack("aa4"); echo $stack->Top_Stack(),'<br />'; $stack->Push_Stack("aa5"); $stack->Push_Stack("aa6"); $stack->Pop_Stack(); $stack->Pop_Stack(); $stack->Pop_Stack(); $stack->Pop_Stack(); $stack->Pop_Stack(); $stack->Pop_Stack();
Running result:
栈空着呢 aa:哥入栈了! aa1:哥入栈了! aa1:哥走了! aa2:哥入栈了! aa3:哥入栈了! aa4:哥入栈了! aa4 栈满了 栈满了 aa4:哥走了! aa3:哥走了! aa2:哥走了! aa:哥走了! 栈空着呢 栈空着呢
Case: Stack-based advanced calculator
When we get a string operation expression, how do we get its operation result?
At this time we can use the stack algorithm to solve this problem very cleverly.
The idea is this: (We use the PHP function substr loop to intercept this string operation expression, and take out the value of this string in turn [we have to intercept from the first character], we will start to intercept the position Set it as a cyclically growing variable, initialized to [$index=0]). At the same time, we need to create two stacks, one to store numbers [$numStack], and one to store operators [$operStack]. We also need one that can judge Whether it is a function of arithmetic symbols, put the intercepted value each time into this custom function, return an identifier that can be distinguished as a number or operator, and determine whether the value is a number or an operator by judging this identifier If the operator is a number, insert it into the number stack. If it is an operator, insert it into the symbol stack. If you insert the number stack, you can insert it directly, but the symbol stack needs special processing [[If the symbol stack is empty, insert it directly, not empty: we need to compare the operation priority of the inserted symbol with the symbols in the stack (canDefine a function to determine the symbol priority. Assume * and / are 1 and + and - are assumed to be 0. Assume that larger numbers have higher priority, so you can get Operator priority), when the priority of the symbol to be inserted is less than or equal to the operator priority at the top of the stack, two values are popped from the number stack. An operator is popped from the symbol stack to operate on them]
The following is a php Example [Refer to Teacher Han Shunping's PHP algorithm tutorial]
<html> <head> <meta http-equiv='content-type' content='text/html;charset=utf-8'/> </head> <h1>高级计算器</h1> <?php /** * 一个栈类 */ class MyStack{ public $top=-1;//默认是-1,表示该栈是空的 public $maxSize=15;//$maxSize表示栈最大容量 public $stack=array();// //入栈的操作 public function push($val) { //先判断栈是否已经满了 if($this->top==$this->maxSize-1){ echo '<br/>栈满,不能添加'; return; } $this->top++; $this->stack[$this->top]=$val; } //出栈的操作,就是把栈顶的值取出 public function pop() { //判断是否栈空 if($this->top==-1){ echo '<br/>栈空1'; return; } //把栈顶的值,取出 $topVal=$this->stack[$this->top]; $this->top--; return $topVal; } //显示栈的所有数据的方法. public function showStack() { if($this->top==-1){ echo '<br/>栈空2'; return; } echo '<br/>当前栈的情况是....'; for($i=$this->top;$i>-1;$i--){ echo '<br/> stack['.$i.']='.$this->stack[$i]; } } //判断是否是一个运算符 public function isOper($val) { if ($val=='+'||$val=='-'||$val=='*'||$val=='/') { return true; } } //判断栈是否为空 public function isEmpty() { if ($this->top==-1) return true; } /** * 比较运算符的优先级 * 我把 * 和/运算符的优先级看作1 * +和- 看作0 * 通过它们之间的比较就能得出它们的优先级谁更高 */ public function PRI($oper) { if ($oper=='*'||$oper=='/') { return 1; } else if ($oper=='+'||$oper=='-') { return 0; } } //返回栈顶端的值 public function getTop() { return $this->stack[$this->top]; } //计算 public function getResult($num1,$num2,$oper) { switch ($oper) { case '+': $res = $num2+$num1; break; case '-': $res = $num2-$num1; break; case '*': $res = $num2*$num1; break; case '/': $res = $num2/$num1; break; } return $res; } } //需要进行运算的表达式 $str = '12+5*2+3-5*2'; //字符串的指针 $index = 0; //声明一个用于组合联系数字的变量 $keepNum = ''; //定义一个数栈和一个符号栈 $numsStack=new MyStack(); $operStack=new MyStack(); while (true) { $val = mb_substr($str,$index,1); //如果是一个符号就入符号栈 否则入数栈 if ($operStack->isOper($val)==true) { //符号入栈前需要判断一下 栈为空直接入栈 不为空需要比较当前运算符与栈顶端的运算符 //如果当前运算符的优先级低于栈内的 则需要运算 if ($operStack->isEmpty()) { $operStack->push($val); } else { while (!$operStack->isEmpty()&&$operStack->PRI($val)<=$operStack->PRI($operStack->getTop())) { //当前符号的优先级要直到高于栈内的时候才能入栈 否则要计算 //当前运算符的优先级低于栈内的 则运算 $num1 = $numsStack->pop(); $num2 = $numsStack->pop(); $oper = $operStack->pop(); $res = $numsStack->getResult($num1,$num2,$oper); //计算完毕将结果入栈 $numsStack->push($res); } //把当前这个符号再入符号栈 $operStack->push($val); } } else { //考虑如果是连续数字的问题 $keepNum.=$val; //先判断是否已经到字符串最后.如果已经到最后,就直接入栈. if ($index==mb_strlen($str)-1) { $numsStack->push($keepNum);//是数字直接入栈 } else { //要判断一下$ch字符的下一个字符是数字还是符号. if ($operStack->isOper(mb_substr($str,$index+1,1))) { $numsStack->push($keepNum); $keepNum=''; } } } $index++;//让$index指向下一个字符. if ($index==mb_strlen($str)) break;//已扫描到字符串的末尾 就退出while循环 } /* 4. 当扫描完毕后,就依次弹出数栈和符号栈的数据,并计算,最终留在数栈的值,就是运算结果,只有符号栈不空就一直计算 */ while (!$operStack->isEmpty()) { $num1 = $numsStack->pop(); $num2 = $numsStack->pop(); $oper = $operStack->pop(); $res = $numsStack->getResult($num1,$num2,$oper); //计算完毕将结果入栈 $numsStack->push($res); } //当退出while后,在数栈一定有一个数,这个数就是最后结果 echo $str.'='.$numsStack->getTop(); ?>
Running results:
12+5*2+3-5*2=15
The above is the detailed content of The definition of the php stack, the push and pop methods, and the complete implementation example of the calculator. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.
