3v4l.org

run code in 300+ PHP versions simultaneously
<?php // Польская нотация. Реализация алгоритма с рекурсией function polish_recursive($str) { // подчистить строку и разделить ее на "стек" $stack=explode(' ',trim(preg_replace('/[[:space:]]{2,}/',' ',$str))); $cnt=count($stack); // если в стеке более 1 элемента if ($cnt>1) { // debug //echo join(' ',$stack).'<br>'; // пройтись по стеку for ($i=0; $i<$cnt; $i++) { if (in_array($stack[$i], array('-', '+', '*', '/', '^'))) { if ($i<2) { return 'error'; } // выполнить операцию, записать в "стек" результат eval('$stack[$i]=$stack[($i-2)]'.$stack[$i].'$stack[($i-1)];'); // изъять из "стека" операнды unset($stack[($i-1)]); unset($stack[($i-2)]); break; } else { // не арифметический знак и не число if (!is_numeric($stack[$i])) { return 'error'; } } } // в стеке ничего не изменилось после выполнения цикла if ($cnt==count($stack)) { return 'error'; } // следующий рекурсивный проход $str=polish_recursive(join(' ',$stack)); } // результат return($str); } echo polish_recursive('(a+b)*c^d^e-f/(g+h/i)');
Output for 4.3.0 - 4.3.11, 4.4.0 - 4.4.9, 5.0.0 - 5.0.5, 5.1.0 - 5.1.6, 5.2.0 - 5.2.17, 5.3.0 - 5.3.29, 5.4.0 - 5.4.45, 5.5.0 - 5.5.36, 5.6.0 - 5.6.28, 7.0.0 - 7.0.20, 7.1.0 - 7.1.20, 7.2.0 - 7.2.33, 7.3.12 - 7.3.33, 7.4.0 - 7.4.33, 8.0.0 - 8.0.30, 8.1.0 - 8.1.28, 8.2.0 - 8.2.18, 8.3.0 - 8.3.6
(a+b)*c^d^e-f/(g+h/i)

preferences:
234.78 ms | 406 KiB | 347 Q