我需要從數組中識別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