PHP实现的简单四则运算计算器功能示例
本文实例讲述了PHP实现的简单四则运算计算器功能。分享给大家供大家参考,具体如下:
php实现一个简单的四则运算计算器(还不支持括号的优先级)。利用栈这种数据结构来计算表达式很赞。
这里可以使用栈的结构,由于php的数组“天然”就有栈的特性,这里直接就利用了数组。当然可以使用栈结构写,道理一样的。
前辈(波兰一位科学家)在计算带有括号的四则表达式,利用逆波兰算法(后缀表达法)。简直神了!!其实代码code并不难,难的是算法的指导,要先理解算法,才能编码。
=$length||isOper($str_arr[$i+1])){//下一个是运算符或者到头了,则把数字塞进数字栈
array_push($num_arr,$pre_num);
$pre_num='';
}
//符号判断优先级,选择是否入栈
}elseif(isOper($val)){
if(count($op_arr)>0){
//判断优先级,只要不大于符号栈顶的优先级,就开始计算,直到优先级大于了栈顶的,计算后才再把这个运算符入栈
while(end($op_arr)&&priority($val)<=priority(end($op_arr))){
calc($num_arr,$op_arr);
}
}
array_push($op_arr,$val);
}
}
//echo'';
//print_r($num_arr);
//print_r($op_arr);
//计算栈里剩余的
while(count($num_arr)>0){
calc($num_arr,$op_arr);
if(count($num_arr)==1){
$result=array_pop($num_arr);
break;
}
}
echo$str,'=',$result;
//计算,获取数字栈的两个数,符号栈顶的运算符
functioncalc(&$num_arr,&$op_arr){
if(count($num_arr)>0){
$num1=array_pop($num_arr);
$num2=array_pop($num_arr);
$op=array_pop($op_arr);
if($op=='*')$re=$num1*$num2;
if($op=='/')$re=$num2/$num1;//这里注意顺序,栈是先进后出,所以$num2是被除数
if($op=='+')$re=$num2+$num1;
if($op=='-')$re=$num2-$num1;
array_push($num_arr,$re);
}
}
//获取优先级
functionpriority($str){
if($str=='*'||$str=='/'){
return1;
}else{
return0;
}
}
//判断是否是运算符
functionisOper($oper){
$oper_array=array('+','-','*','/');
if(in_array($oper,$oper_array)){
returntrue;
}
returnfalse;
}
运行结果:
10+6*2-18/2-2=11
PS:这里再为大家推荐几款计算工具供大家进一步参考借鉴:
在线一元函数(方程)求解计算工具:
http://tools.jb51.net/jisuanqi/equ_jisuanqi
科学计算器在线使用_高级计算器在线计算:
http://tools.jb51.net/jisuanqi/jsqkexue
在线计算器_标准计算器:
http://tools.jb51.net/jisuanqi/jsq
更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP数学运算技巧总结》、《PHP运算与运算符用法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP数据结构与算法教程》、《php程序设计算法总结》及《php正则表达式用法总结》
希望本文所述对大家PHP程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。