当前位置:首页 > PHP教程 > php应用 > 列表

PHP实现的简单四则运算计算器功能示例

发布:smiling 来源: PHP粉丝网  添加日期:2021-08-22 13:43:14 浏览: 评论:0 

这篇文章主要介绍了PHP实现的简单四则运算计算器功能,结合实例形式分析了PHP基于堆栈实现的表达式运算功能,需要的朋友可以参考下。

本文实例讲述了PHP实现的简单四则运算计算器功能,分享给大家供大家参考,具体如下:

php实现一个简单的四则运算计算器(还不支持括号的优先级)。利用栈这种数据结构来计算表达式很赞。

这里可以使用栈的结构,由于php的数组“天然”就有栈的特性,这里直接就利用了数组。当然可以使用栈结构写,道理一样的。

前辈(波兰一位科学家)在计算带有括号的四则表达式,利用逆波兰算法(后缀表达法)。简直神了!!其实代码code并不难,难的是算法的指导,要先理解算法,才能编码。

  1. <?php 
  2. $num_arr = array();// 声明数字栈 
  3. $op_arr = array();// 声明符号栈 
  4. $str = "10+6*2-18/2-2"
  5. preg_match_all('/./'$str$arr);// 把运算串分解成每个字符到$arr数组 
  6. $str_arr = $arr[0]; 
  7. $length = count($str_arr); 
  8. $pre_num = ''
  9. // 开始入栈 
  10. for($i=0; $i<$length$i++){ 
  11.   $val = $str_arr[$i]; 
  12.   // 数字 
  13.   if (is_numeric($val)){ 
  14.     $pre_num .= $val;// 兼顾下一个字符可能也是数字的情况(多位数) 
  15.     if($i+1>=$length || isOper($str_arr[$i+1])){// 下一个是运算符或者到头了,则把数字塞进数字栈 
  16.       array_push($num_arr$pre_num); 
  17.       $pre_num = ''
  18.     } 
  19.   // 符号判断优先级,选择是否入栈 
  20.   } else if (isOper($val)){ 
  21.     if (count($op_arr)>0){ 
  22.       // 判断优先级,只要不大于符号栈顶的优先级,就开始计算,直到优先级大于了栈顶的,计算后才再把这个运算符入栈 
  23.       while (end($op_arr) && priority($val) <= priority(end($op_arr))){ 
  24.         calc($num_arr$op_arr); 
  25.       } 
  26.     } 
  27.     array_push($op_arr$val); 
  28.   } 
  29. //echo '<pre>'; 
  30. //print_r($num_arr); 
  31. //print_r($op_arr); 
  32. // 计算栈里剩余的 
  33. while(count($num_arr)>0){ 
  34.   calc($num_arr$op_arr); 
  35.   if (count($num_arr)==1){ 
  36.     $result = array_pop($num_arr); 
  37.     break
  38.   } 
  39. echo $str,' = '$result
  40. // 计算,获取数字栈的两个数,符号栈顶的运算符 
  41. function calc(&$num_arr, &$op_arr){ 
  42.   if (count($num_arr)>0){ 
  43.     $num1 = array_pop($num_arr); 
  44.     $num2 = array_pop($num_arr); 
  45.     $op = array_pop($op_arr); 
  46.     if ($op=='*'$re = $num1*$num2
  47.     if ($op=='/'$re = $num2/$num1;// 这里注意顺序,栈是先进后出,所以$num2是被除数 
  48.     if ($op=='+'$re = $num2+$num1
  49.     if ($op=='-'$re = $num2-$num1
  50.     array_push($num_arr$re); 
  51.   } 
  52. // 获取优先级 
  53. function priority($str){ 
  54.   if ($str == '*' || $str == '/'){ 
  55.     return 1; 
  56.   } else { 
  57.     return 0; 
  58.   } 
  59. // 判断是否是运算符 
  60. function isOper($oper){ 
  61.   $oper_array = array('+','-','*','/'); 
  62.   if (in_array($oper$oper_array)){ 
  63.     return true; 
  64.   } 
  65.   return false; 

运行结果:10+6*2-18/2-2 = 11

Tags: PHP计算器

分享到: