我需要从数组中识别unique urls
。php array对于urls唯一
以下所有变体,都应视为等于:
http://google.com
https://google.com
http://www.google.com
https://www.google.com
www.google.com
google.com
我有以下溶液:
public static function array_unique_url(array $array) : array
{
$uniqueArray = [];
foreach($array as $item) {
if(!self::in_array_url($item, $uniqueArray)){
$uniqueArray[] = $item;
}
}
return $uniqueArray;
}
public static function in_array_url(string $needle, array $haystack): bool {
$haystack = array_map([self::class, 'normalizeUrl'], $haystack);
$needle = self::normalizeUrl($needle);
return in_array($needle, $haystack);
}
public static function normalizeUrl(string $url) {
$url = strtolower($url);
return preg_replace('#^(https?://)?(www.)?#', '', $url);
}
然而,这不是很有效为O(n^2)。任何人都可以指出我更好的解决方案吗?
你能解释一下你的问题一次? –
@SahilGulati我认为这很清楚。人们理解这个问题 – Chris