3v4l.org

run code in 300+ PHP versions simultaneously
<?php $data = array(8,4,1,9,5,7,3,2,6,0); function merge_sort($list){ var_dump($list); if(count($list) <= 1) { return $list; } $middle = count($list)/2; $left = merge_sort(array_slice($list, 0, $middle)); $right = merge_sort(array_slice($list, $middle+1, count($list))); $data = array(); for($x = 0;$x < count($list); $x++){ if($x < count($left)){ $data[$x] = $left[$x]; } if($x >= count($left) && $x < count($right)){ $data[$x] = $right[$x]; } } return $data; } var_dump(merge_sort($data));
Output for 8.1.0 - 8.1.28, 8.2.0 - 8.2.18, 8.3.0 - 8.3.6
array(10) { [0]=> int(8) [1]=> int(4) [2]=> int(1) [3]=> int(9) [4]=> int(5) [5]=> int(7) [6]=> int(3) [7]=> int(2) [8]=> int(6) [9]=> int(0) } array(5) { [0]=> int(8) [1]=> int(4) [2]=> int(1) [3]=> int(9) [4]=> int(5) } Deprecated: Implicit conversion from float 2.5 to int loses precision in /in/3K52p on line 13 array(2) { [0]=> int(8) [1]=> int(4) } array(1) { [0]=> int(8) } array(0) { } Deprecated: Implicit conversion from float 3.5 to int loses precision in /in/3K52p on line 14 array(2) { [0]=> int(9) [1]=> int(5) } array(1) { [0]=> int(9) } array(0) { } array(4) { [0]=> int(3) [1]=> int(2) [2]=> int(6) [3]=> int(0) } array(2) { [0]=> int(3) [1]=> int(2) } array(1) { [0]=> int(3) } array(0) { } array(1) { [0]=> int(0) } array(1) { [0]=> int(8) }
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.38, 5.6.0 - 5.6.28, 7.0.0 - 7.0.20, 7.1.0 - 7.1.25, 7.2.0 - 7.2.33, 7.3.0 - 7.3.33, 7.4.0 - 7.4.33, 8.0.0 - 8.0.30
array(10) { [0]=> int(8) [1]=> int(4) [2]=> int(1) [3]=> int(9) [4]=> int(5) [5]=> int(7) [6]=> int(3) [7]=> int(2) [8]=> int(6) [9]=> int(0) } array(5) { [0]=> int(8) [1]=> int(4) [2]=> int(1) [3]=> int(9) [4]=> int(5) } array(2) { [0]=> int(8) [1]=> int(4) } array(1) { [0]=> int(8) } array(0) { } array(2) { [0]=> int(9) [1]=> int(5) } array(1) { [0]=> int(9) } array(0) { } array(4) { [0]=> int(3) [1]=> int(2) [2]=> int(6) [3]=> int(0) } array(2) { [0]=> int(3) [1]=> int(2) } array(1) { [0]=> int(3) } array(0) { } array(1) { [0]=> int(0) } array(1) { [0]=> int(8) }

preferences:
234.29 ms | 406 KiB | 371 Q