3v4l.org

run code in 300+ PHP versions simultaneously
<?php $steps = 0; $arr = explode('|', '1|2|3|4|5'); $arr = array_reverse($arr); function quSort($input) { $input = array_values($input); $newArray = array($input[0]); array_shift($input); $end = $start = $newArray[0]; array_walk($input, function($num) use ($end, $start, &$newArray) { if ($num <= $start) { $start = $num; array_unshift($newArray, $num); } else if ($num >= $end) { $end = $num; $newArray[] = $num; } else { $end2 = count($newArray); $start2 = 0; $var = closer($num, $start, $end); if ($var === $end) { for($i = $end2-1; $i >= $start2; $i--) { if ($num > $newArray[$i] || $num === $newArray[$i]) { array_splice($newArray, $i, 0, array($num)); break 1; } } } else { for($i = $start2; $i < $end2; $i++) { if ($num < $newArray[$i] || $num === $newArray[$i]) { array_splice($newArray, $i, 0, array($num)); break 1; } } } } }); return $newArray; } function quickSort($input, &$steps) { $min = null; $max = null; $medium = null; if (count($input) === 2) { $input = array_values($input); if ($input[0] > $input[1]) { return array($input[1], $input[0]); } else { return array($input[0], $input[1]); } } else if (countOfNumbers($input) == 2) { $array = array(); $biggestNum = reset($input); foreach($input as $num) { if (empty($array)) { array_push($array, $num); } else { if ($biggestNum === $num) { array_push($array, $num); } else if ($biggestNum > $num) { array_unshift($array, $num); } else if ($num > $biggestNum) { array_push($array, $num); $biggestNum = $num; } } } return $array; } else if (!isRight($input, $min, $max, $medium)) { $middle = $medium; $left = array(); $right = array(); foreach ($input as $num) { if ($num > $middle) { array_push($right, $num); } else if ($num <= $middle) { array_push($left, $num); } } $arr = array(); if (count($left) > 0) { if (sameCheck($left)) { $arr = array_merge($arr, $left); } else { $steps++; $arr = array_merge($arr, quickSort($left, $steps)); } } if (count($right) > 0) { if (sameCheck($right)) { $arr = array_merge($arr, $right); } else { $steps++; $arr = array_merge($arr, quickSort($right, $steps)); } } return $arr; } else { return $input; } } function sameCheck ($input) { $oldInput = reset($input); foreach($input as $keys) { if ($oldInput !== $keys) { return false; } } return true; } function countOfNumbers($input) { $arr = array(); foreach ($input as $num) { if (!in_array($num, $arr)) { array_push($arr, $num); } } return count($arr); } function isRight ($input, &$min, &$max, &$medium) { $before = null; $check = true; foreach($input as $num) { if ($before === null) { $before = $num; $min = $num; $max = $num; $medium = $num; } if ($min > $num) { $min = $num; } else if ($max < $num) { $max = $num; } //echo implode('|', array($max, $min, $medium, $num)) . PHP_EOL; if ($num != $medium && $num < $max && $num > $min) { $medium = closer($max + $min, $medium, $num); } else if (($num != $medium && $medium === $min && $medium < $max)|| ($min === $max && $medium != $max)){ $medium = $max; } /*if () { $medium = $num; }*/ if ($num < $before) { $check = false; } $before = $num; } //$medium = ($max + $min) / 2/; return $check; } function closer($to, $medium, $new) { $to = floor($to / 2); if (abs($to - $medium) > abs($new - $to)) { return $new; } else { return $medium; } } /*$start = microtime(true); echo implode('|', quickSort($arr, $steps)) . PHP_EOL; echo $date - $start; */ $date = microtime(true); echo PHP_EOL; echo implode('|', $arr) . PHP_EOL; echo implode('|', quSort($arr)) . PHP_EOL; $date2 = microtime(true); echo $date2 - $date; echo PHP_EOL; echo implode('|', $arr) . PHP_EOL;; sort($arr); echo implode('|', $arr). PHP_EOL; $date3= microtime(true); echo $date3 - $date2; if (($date2 - $date) > ($date3 - $date2)) { echo PHP_EOL . 'still slower'; }

Here you find the average performance (time & memory) of each version. A grayed out version indicates it didn't complete successfully (based on exit-code).

VersionSystem time (s)User time (s)Memory (MiB)
7.2.00.0030.00619.63
7.1.70.0000.00817.18
7.1.60.0070.01019.40
7.1.50.0070.01416.63
7.1.00.0030.07722.28
7.0.200.0000.00716.86
7.0.140.0030.07321.95
7.0.100.0300.05720.00
7.0.90.0500.08320.00
7.0.80.0600.07019.91
7.0.70.0370.04319.96
7.0.60.0570.08019.89
7.0.50.0630.07020.42
7.0.40.0070.05020.00
7.0.30.0030.08020.14
7.0.20.0030.09020.13
7.0.10.0170.07319.99
7.0.00.0130.08020.03
5.6.280.0070.06321.08
5.6.250.0070.08720.61
5.6.240.0100.07020.71
5.6.230.0000.07320.73
5.6.220.0000.08320.72
5.6.210.0070.08020.81
5.6.200.0030.08721.18
5.6.190.0070.08021.16
5.6.180.0100.08320.99
5.6.170.0070.06721.15
5.6.160.0100.07721.16
5.6.150.0030.04720.98
5.6.140.0030.08720.96
5.6.130.0170.07021.14
5.6.120.0030.05320.97
5.6.110.0130.07321.04
5.6.100.0170.06721.16
5.6.90.0100.08321.09
5.6.80.0170.06020.36
5.6.70.0170.07020.53
5.6.60.0130.05320.49
5.6.50.0100.07720.43
5.6.40.0030.08020.34
5.6.30.0100.08020.46
5.6.20.0170.06720.35
5.6.10.0100.06320.45
5.6.00.0070.05720.41
5.5.380.0100.07720.48
5.5.370.0130.06320.49
5.5.360.0030.08320.41
5.5.350.0100.08020.51
5.5.340.0100.07020.96
5.5.330.0030.07020.91
5.5.320.0100.07320.89
5.5.310.0100.07720.77
5.5.300.0170.07020.86
5.5.290.0170.07320.92
5.5.280.0030.06720.91
5.5.270.0000.09020.93
5.5.260.0070.05320.84
5.5.250.0100.07720.78
5.5.240.0070.06020.34
5.5.230.0100.07320.18
5.5.220.0100.08020.13
5.5.210.0100.07720.33
5.5.200.0100.08020.22
5.5.190.0130.07720.20
5.5.180.0030.08020.26
5.5.160.0100.05020.28
5.5.150.0130.06720.23
5.5.140.0070.07720.22
5.5.130.0030.07720.02
5.5.120.0100.07020.32
5.5.110.0030.08720.31
5.5.100.0070.07019.99
5.5.90.0070.08020.11
5.5.80.0130.06320.11
5.5.70.0070.07719.97
5.5.60.0100.07320.19
5.5.50.0100.07320.01
5.5.40.0130.06720.13
5.5.30.0100.07320.14
5.5.20.0200.07320.06
5.5.10.0100.08020.10
5.5.00.0100.07020.05
5.4.450.0030.08019.18
5.4.440.0070.06719.28
5.4.430.0070.07719.36
5.4.420.0170.07019.35
5.4.410.0070.06319.24
5.4.400.0100.07019.00
5.4.390.0130.07018.85
5.4.380.0070.07318.88
5.4.370.0170.07019.13
5.4.360.0070.04719.23
5.4.350.0170.06319.04
5.4.340.0030.07718.91
5.4.320.0170.06319.05
5.4.310.0070.07018.88
5.4.300.0200.05719.04
5.4.290.0070.07318.88
5.4.280.0030.09319.11
5.4.270.0100.07019.04
5.4.260.0130.06019.13
5.4.250.0070.04318.96
5.4.240.0100.07019.03
5.4.230.0170.06718.87
5.4.220.0100.07319.04
5.4.210.0030.07319.02
5.4.200.0170.06718.88
5.4.190.0070.05019.09
5.4.180.0070.07319.05
5.4.170.0070.06019.22
5.4.160.0030.08719.01
5.4.150.0030.08019.21
5.4.140.0070.07716.48
5.4.130.0030.07316.39
5.4.120.0030.08016.47
5.4.110.0100.07716.39
5.4.100.0070.07016.40
5.4.90.0100.07016.53
5.4.80.0030.07016.53
5.4.70.0100.06716.38
5.4.60.0070.06716.50
5.4.50.0100.06716.37
5.4.40.0070.07716.30
5.4.30.0100.06716.26
5.4.20.0030.08016.35
5.4.10.0030.06316.42
5.4.00.0070.07715.90
5.3.290.0130.06714.70
5.3.280.0030.07314.77
5.3.270.0130.07014.79
5.3.260.0100.07014.70
5.3.250.0100.07314.77
5.3.240.0070.07714.60
5.3.230.0070.07714.76
5.3.220.0000.07714.65
5.3.210.0130.07314.56
5.3.200.0070.07714.55
5.3.190.0100.07714.68
5.3.180.0100.07314.61
5.3.170.0100.07014.58
5.3.160.0100.07014.65
5.3.150.0000.08314.73
5.3.140.0070.04014.68
5.3.130.0030.04714.59
5.3.120.0030.07314.54
5.3.110.0070.05714.54
5.3.100.0100.06014.08
5.3.90.0100.07014.01
5.3.80.0100.06314.19
5.3.70.0100.06714.14
5.3.60.0030.07714.08
5.3.50.0200.05713.93
5.3.40.0100.04313.99
5.3.30.0030.04314.09
5.3.20.0070.07313.77
5.3.10.0070.06013.77
5.3.00.0070.06013.73

preferences:
37.2 ms | 401 KiB | 5 Q