3v4l.org

run code in 300+ PHP versions simultaneously
<?php $steps = 0; $arr = explode('|', '1|2|3|4|5'); 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.0070.00718.96
7.1.70.0030.00617.11
7.1.60.0030.01719.40
7.1.50.0000.01916.64
7.1.00.0130.06722.57
7.0.200.0060.00316.77
7.0.140.0130.06321.96
7.0.100.0170.04719.96
7.0.90.0100.08720.05
7.0.80.0070.08019.92
7.0.70.0130.08720.06
7.0.60.0070.04720.10
7.0.50.0300.07020.41
7.0.40.0130.06320.08
7.0.30.0030.06720.08
7.0.20.0100.07020.05
7.0.10.0030.07320.14
7.0.00.0100.08019.99
5.6.280.0070.07020.96
5.6.250.0100.07020.66
5.6.240.0030.05320.73
5.6.230.0030.07320.57
5.6.220.0100.08320.71
5.6.210.0130.07020.72
5.6.200.0070.07021.09
5.6.190.0130.04721.05
5.6.180.0070.08021.08
5.6.170.0130.08020.98
5.6.160.0070.04721.00
5.6.150.0030.08721.09
5.6.140.0030.08321.18
5.6.130.0130.08021.14
5.6.120.0070.08321.10
5.6.110.0200.06721.03
5.6.100.0100.04721.10
5.6.90.0070.08020.96
5.6.80.0100.07320.38
5.6.70.0070.07320.46
5.6.60.0070.04720.44
5.6.50.0030.06720.46
5.6.40.0070.06320.41
5.6.30.0100.04720.48
5.6.20.0130.07020.38
5.6.10.0030.06020.43
5.6.00.0100.07320.43
5.5.380.0130.07720.46
5.5.370.0100.04320.38
5.5.360.0100.06320.48
5.5.350.0130.07320.48
5.5.340.0070.04720.96
5.5.330.0100.07320.94
5.5.320.0030.08320.97
5.5.310.0070.08020.88
5.5.300.0100.07720.77
5.5.290.0100.04720.86
5.5.280.0000.05020.92
5.5.270.0030.05020.95
5.5.260.0070.08320.91
5.5.250.0070.07020.61
5.5.240.0170.06720.23
5.5.230.0100.05320.33
5.5.220.0030.06320.19
5.5.210.0070.05020.18
5.5.200.0130.05020.21
5.5.190.0070.08020.25
5.5.180.0100.07720.11
5.5.160.0070.05720.29
5.5.150.0100.04020.16
5.5.140.0100.07020.25
5.5.130.0000.08020.28
5.5.120.0070.08020.30
5.5.110.0230.06320.30
5.5.100.0070.05720.11
5.5.90.0130.05320.10
5.5.80.0100.04020.13
5.5.70.0030.07320.08
5.5.60.0130.06020.07
5.5.50.0170.04720.15
5.5.40.0070.05020.13
5.5.30.0070.07719.99
5.5.20.0030.08020.17
5.5.10.0030.06720.05
5.5.00.0070.08020.16
5.4.450.0100.07719.55
5.4.440.0130.07319.47
5.4.430.0070.08019.27
5.4.420.0030.08019.27
5.4.410.0130.05719.25
5.4.400.0070.04719.14
5.4.390.0070.08018.90
5.4.380.0100.06319.04
5.4.370.0030.07319.17
5.4.360.0070.06018.86
5.4.350.0070.07719.17
5.4.340.0070.07319.04
5.4.320.0070.03718.89
5.4.310.0070.03718.95
5.4.300.0170.06719.05
5.4.290.0070.07719.16
5.4.280.0070.06719.23
5.4.270.0030.08019.04
5.4.260.0100.05019.16
5.4.250.0070.08019.23
5.4.240.0070.05319.15
5.4.230.0000.08018.94
5.4.220.0200.05319.08
5.4.210.0070.06719.13
5.4.200.0130.03718.86
5.4.190.0170.07719.02
5.4.180.0100.03319.15
5.4.170.0130.07018.87
5.4.160.0100.06719.13
5.4.150.0000.08319.17
5.4.140.0130.06716.49
5.4.130.0070.06016.48
5.4.120.0000.06316.48
5.4.110.0070.04316.39
5.4.100.0130.05716.44
5.4.90.0100.07016.57
5.4.80.0100.07016.38
5.4.70.0070.07316.47
5.4.60.0000.07716.49
5.4.50.0070.07016.50
5.4.40.0030.04316.53
5.4.30.0070.06316.52
5.4.20.0130.06316.41
5.4.10.0100.06016.49
5.4.00.0070.05315.65
5.3.290.0070.03714.67
5.3.280.0030.05014.73
5.3.270.0070.07014.60
5.3.260.0170.06714.65
5.3.250.0130.06314.65
5.3.240.0170.06014.77
5.3.230.0000.04314.82
5.3.220.0200.05714.57
5.3.210.0070.05014.70
5.3.200.0030.03714.61
5.3.190.0100.07314.74
5.3.180.0070.07014.69
5.3.170.0070.05314.73
5.3.160.0030.04314.69
5.3.150.0070.05714.77
5.3.140.0100.07014.61
5.3.130.0070.03714.75
5.3.120.0130.06714.56
5.3.110.0070.07314.67
5.3.100.0070.03314.24
5.3.90.0030.07014.22
5.3.80.0100.03714.13
5.3.70.0070.05714.11
5.3.60.0000.08014.12
5.3.50.0030.04314.00
5.3.40.0170.06013.94
5.3.30.0030.07314.09
5.3.20.0030.05013.67
5.3.10.0030.07313.77
5.3.00.0070.04013.63

preferences:
38.26 ms | 401 KiB | 5 Q