欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2017年11月10日 11:47:35   作者:幻世2012  
這篇文章主要介紹了PHP實現(xiàn)基于棧的后綴表達式求值功能,簡單描述了后綴表達式的概念并結(jié)合實例形式分析了php使用棧實現(xiàn)后綴表達式求值的相關(guān)操作技巧,需要的朋友可以參考下

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

后綴表達式概述

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

實現(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();
?>

運行結(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é)運算技巧總結(jié)

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

相關(guān)文章

  • PHP通過串口實現(xiàn)發(fā)送短信

    PHP通過串口實現(xiàn)發(fā)送短信

    本文給大家詳細介紹了,如何使用php通過串口來實現(xiàn)發(fā)送短信的思路以及具體的實現(xiàn)代碼,十分的實用,有需要的小伙伴可以參考下。
    2015-07-07
  • PHP實現(xiàn)對xml進行簡單的增刪改查(CRUD)操作示例

    PHP實現(xiàn)對xml進行簡單的增刪改查(CRUD)操作示例

    這篇文章主要介紹了PHP實現(xiàn)對xml進行簡單的增刪改查(CRUD)操作,結(jié)合簡單實例形式分析了php針對xml文件數(shù)據(jù)進行載入、修改等相關(guān)操作技巧,需要的朋友可以參考下
    2017-05-05
  • PHP管理依賴(dependency)關(guān)系工具 Composer的自動加載(autoload)

    PHP管理依賴(dependency)關(guān)系工具 Composer的自動加載(autoload)

    Composer 是PHP的一個包依賴管理工具,類似Ruby中的RubyGems或者Node中的NPM,它并非官方,但現(xiàn)在已經(jīng)非常流行。此文并不介紹如何使用Composer,而是關(guān)注于它的autoload的內(nèi)容吧。
    2014-08-08
  • PHP靜態(tài)文件生成類實例

    PHP靜態(tài)文件生成類實例

    這篇文章主要介紹了PHP靜態(tài)文件生成類,以實例形式演示了PHP生成靜態(tài)文件的方法,并封裝成類文件便于使用,是非常實用的技巧,需要的朋友可以參考下
    2014-11-11
  • php實現(xiàn)的錯誤處理封裝類實例

    php實現(xiàn)的錯誤處理封裝類實例

    這篇文章主要介紹了php實現(xiàn)的錯誤處理封裝類,結(jié)合具體實例形式分析了php錯誤判斷、提示及日志相關(guān)操作技巧,需要的朋友可以參考下
    2017-06-06
  • 修改php.ini實現(xiàn)Mysql導(dǎo)入數(shù)據(jù)庫文件最大限制的修改方法

    修改php.ini實現(xiàn)Mysql導(dǎo)入數(shù)據(jù)庫文件最大限制的修改方法

    這里介紹修改php.ini實現(xiàn)Mysql導(dǎo)入數(shù)據(jù)庫文件最大限制的修改方法,簡單說明了wampserver服務(wù)器上針對php.ini配置文件上傳限制參數(shù)、內(nèi)存限制參數(shù)以及post傳輸參數(shù)等修改方法,需要的朋友可以參考一下
    2007-12-12
  • 編寫PHP腳本清除WordPress頭部冗余代碼的方法講解

    編寫PHP腳本清除WordPress頭部冗余代碼的方法講解

    這篇文章主要介紹了編寫PHP腳本清除WordPress頭部冗余代碼的方法講解,很多meta信息于用戶于SEO都無實際用處,放在那里還有礙觀瞻...需要的朋友可以參考下
    2016-03-03
  • php二分法在IP地址查詢中的應(yīng)用

    php二分法在IP地址查詢中的應(yīng)用

    前段時間做數(shù)據(jù)分析,需要大量的IP地址查詢(每秒鐘近萬次檢索),首先考慮到使用數(shù)據(jù)庫。
    2008-08-08
  • PhpDocumentor 2安裝以及生成API文檔的方法

    PhpDocumentor 2安裝以及生成API文檔的方法

    phpDocumentor 2是一個可以分析php源代碼和注釋塊并生成文檔的程序?;趐hpdocumentor 1和javadoc啟發(fā)而來,它持續(xù)創(chuàng)新的使用了一些新技術(shù)和支持php的新特性。
    2014-05-05
  • PHP對XML內(nèi)容進行修改和刪除實例代碼

    PHP對XML內(nèi)容進行修改和刪除實例代碼

    這篇文章給大家主要介紹了利用PHP對XML內(nèi)容進行修改和刪除的原理和方法,文中通過示例代碼介紹的很詳細,相信對大家的理解和學(xué)習(xí)很有幫助,感興趣的朋友們可以參考借鑒,下面來一起看看吧。
    2016-10-10

最新評論