<?php
$number = 600851475143;

echo max(factorize($number));

/**
 * Returns a sorted array of the prime factorization of $num
 * @staticvar array $aFactors
 * @param type int Number to factorize
 * @return type array Prime factors
 */
function factorize($num) {
	// Returns a sorted array of the prime factorization of $num 
	// Caches prior results.  Returns empty array for |$num|<2 
	// eg. factorize(360) => [5, 3, 3, 2, 2, 2] 
	static $aFactors = array();
	if (2 > $num = abs($num))
		return array();  // negatives, 1, 0 

	if ($aFactors[$key = "x$num"]) {	 // handles doubles 
		// Been there, done that 
		if (($factor = $aFactors[$key]) == $num)
			return array($num);
		return array_merge(factorize($num / $factor), array($factor));
	}

	// Find a smallest factor 
	for ($sqrt = sqrt($num), $factor = 2; $factor <= $sqrt; ++$factor)
		if (floor($num / $factor) == $num / $factor)
			return array_merge(factorize($num / $factor), array($aFactors[$key] = $factor));

	return (array($aFactors[$key] = $num));
}