【发布时间】:2017-05-05 10:29:30
【问题描述】:
我需要从数组中识别unique 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 我认为这很清楚。人们理解这个问题
标签: php arrays regex array-unique