佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > PHP實(shí)現(xiàn)基于棧的后綴表達(dá)式求值功能

PHP實(shí)現(xiàn)基于棧的后綴表達(dá)式求值功能

熱門標(biāo)簽:阿里云 銀行業(yè)務(wù) 電子圍欄 團(tuán)購網(wǎng)站 Linux服務(wù)器 服務(wù)器配置 Mysql連接數(shù)設(shè)置 科大訊飛語音識別系統(tǒng)

本文實(shí)例講述了PHP實(shí)現(xiàn)基于棧的后綴表達(dá)式求值功能。分享給大家供大家參考,具體如下:

后綴表達(dá)式概述

后綴表達(dá)式,指的是不包含括號,運(yùn)算符放在兩個運(yùn)算對象的后面,所有的計算按運(yùn)算符出現(xiàn)的順序,嚴(yán)格從左向右進(jìn)行(不再考慮運(yùn)算符的優(yōu)先規(guī)則)。

實(shí)現(xiàn)代碼:

?php
class Stack{
  public $stack;
  public $stack_top;
  public function __construct(){
    $this->stack=array();
    $this->stack_top=-1;
  }
  public function push($data){
    $this->stack[]=$data;
    $this->stack_top++;
  }
  public function pop(){
    if(!$this->is_empty())
    {
      $this->stack_top--;
      return array_pop($this->stack);
    }else
    {
      echo "stack is empty";
    }
  }
  public function is_empty(){
    if($this->stack_top==-1)
    return true;
  }
}
$string="1243-*+63/-";
$arrs=str_split($string);
echo var_export($arrs);
$stack=new Stack();
foreach($arrs as $arr){
  switch($arr){
    case "+":$one=$stack->pop();$two=$stack->pop();$temp=$two + $one;$stack->push($temp);break;
    case "-":$one=$stack->pop();$two=$stack->pop();$temp=$two - $one;$stack->push($temp);break;
    case "*":$one=$stack->pop();$two=$stack->pop();$temp=$two * $one;$stack->push($temp);break;
    case "/":$one=$stack->pop();$two=$stack->pop();$temp=$two / $one;$stack->push($temp);break;
    default:$stack->push($arr);
  }
}
echo $stack->pop();
?>

運(yùn)行結(jié)果:

array (
 0 => '1',
 1 => '2',
 2 => '4',
 3 => '3',
 4 => '-',
 5 => '*',
 6 => '+',
 7 => '6',
 8 => '3',
 9 => '/',
 10 => '-',
)1

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》

希望本文所述對大家PHP程序設(shè)計有所幫助。

您可能感興趣的文章:
  • PHP基于數(shù)組實(shí)現(xiàn)的堆棧和隊列功能示例
  • 關(guān)于PHP堆棧與列隊的學(xué)習(xí)
  • php線性表的入棧與出棧實(shí)例分析
  • PHP基于堆棧實(shí)現(xiàn)的高級計算器功能示例
  • PHP實(shí)現(xiàn)的棧數(shù)據(jù)結(jié)構(gòu)示例【入棧、出棧、遍歷?!?/li>
  • PHP使用數(shù)組實(shí)現(xiàn)隊列
  • php實(shí)現(xiàn)的雙向隊列類實(shí)例
  • 隊列在編程中的實(shí)際應(yīng)用(php)
  • php基于雙向循環(huán)隊列實(shí)現(xiàn)歷史記錄的前進(jìn)后退等功能
  • PHP實(shí)現(xiàn)的鏈?zhǔn)疥犃薪Y(jié)構(gòu)示例
  • PHP使用兩個棧實(shí)現(xiàn)隊列功能的方法

標(biāo)簽:衡水 廣元 蚌埠 萍鄉(xiāng) 衢州 江蘇 大理 棗莊

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP實(shí)現(xiàn)基于棧的后綴表達(dá)式求值功能》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    讷河市| 微博| 岑溪市| 武乡县| 乌兰浩特市| 五指山市| 丹寨县| 苍梧县| 双牌县| 饶河县| 彭阳县| 罗源县| 台北县| 霍山县| 桂林市| 海城市| 龙口市| 东兴市| 兴义市| 甘德县| 玛沁县| 务川| 景宁| 延边| 娱乐| 车险| 三原县| 洛隆县| 乌鲁木齐县| 襄汾县| 景泰县| 霍城县| 扶绥县| 望江县| 贵德县| 临澧县| 顺义区| 奉新县| 富宁县| 吉林市| 建昌县|