3v4l.org

run code in 300+ PHP versions simultaneously
<?php class Sums { public function getAllSums($total) { if ($total < 0) { return array(); } $return = array(); // Reducing the problem linearly, examining one integer at a time for ($i = $total; $i >= 1; $i--) { $subTotal = $this->getSumsFor($i, $total); foreach ($subTotal as $item) { $return[] = $item; } } return $return; } private function getSumsFor($currentValue, $total) { $return = array(); // Base case where the current iteration is its own sum if ($currentValue == $total) { $return[] = array($total); return $return; } // Base case where we have all the 1's summed up else if ($currentValue == 1) { $sum = array(); for ($i = 0; $i < $total; $i++) { $sum[] = 1; } $return[] = $sum; return $return; } $remainder = $total - $currentValue; // Break the problem into a smaller chunk $possibleSums = $this->getAllSums($remainder); foreach ($possibleSums as $row) { // Once we have the sum of the remainder, add the original value back array_unshift($row, $currentValue); $return[] = $row; } return $return; } } $sums = new Sums(); echo '<pre>'; print_r($sums->getAllSums(4)); echo '</pre>';
Output for 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.24 - 5.5.35, 5.6.8 - 5.6.28, 7.0.0 - 7.0.20, 7.1.0 - 7.1.10, 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
<pre>Array ( [0] => Array ( [0] => 4 ) [1] => Array ( [0] => 3 [1] => 1 ) [2] => Array ( [0] => 2 [1] => 2 ) [3] => Array ( [0] => 2 [1] => 1 [2] => 1 ) [4] => Array ( [0] => 1 [1] => 1 [2] => 1 [3] => 1 ) ) </pre>
Output for 4.4.2 - 4.4.9
Parse error: syntax error, unexpected T_STRING, expecting T_OLD_FUNCTION or T_FUNCTION or T_VAR or '}' in /in/SXnXt on line 3
Process exited with code 255.
Output for 4.3.0 - 4.3.1, 4.3.5 - 4.3.11, 4.4.0 - 4.4.1
Parse error: parse error, unexpected T_STRING, expecting T_OLD_FUNCTION or T_FUNCTION or T_VAR or '}' in /in/SXnXt on line 3
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Parse error: parse error, expecting `T_OLD_FUNCTION' or `T_FUNCTION' or `T_VAR' or `'}'' in /in/SXnXt on line 3
Process exited with code 255.

preferences:
226.48 ms | 401 KiB | 311 Q