亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP實現基于棧的后綴表達式求值功能

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

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

后綴表達式概述

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

實現代碼:

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

運行結果:

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

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

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

相關文章

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

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

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

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

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

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

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

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

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

    php實現的錯誤處理封裝類實例

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

    修改php.ini實現Mysql導入數據庫文件最大限制的修改方法

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

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

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

    php二分法在IP地址查詢中的應用

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

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

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

    PHP對XML內容進行修改和刪除實例代碼

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

最新評論