Исходя из вашего примера, я предполагаю, что вы имеете в виду «незначительные изменения в составе кластера», а не «размер кластера».
Если ваша функция именования f()
не может использовать информацию о существующем именидля данного кластера вы должны допустить, чтобы он иногда переименовывался, несмотря на небольшие изменения.Действительно, предположим, что f()
никогда не переименовывает кластер, когда он немного меняется.Начиная с кластера A, вы можете попасть в любой другой кластер B, добавляя или удаляя только один элемент за раз.По построению функция возвратит одно и то же имя для A и B. Поскольку A, B были произвольными, f()
вернет одно и то же имя для всех возможных кластеров - явно бесполезно.
Итак, у вас есть две альтернативы:
(1) функция именования опирается на существующее имя кластера или
(2) функция именования иногда (редко) переименовывает кластер после очень незначительного изменения.
Если вы выберете альтернативу (1), она тривиальна.Вы можете просто назначать имена случайным образом, а затем сохранять их неизменными всякий раз, когда кластер обновляется, если он не слишком отличается (однако вы определяете другое).Учитывая, как все просто, я полагаю, это не то, что вы хотите.
Если вы выберете альтернативу (2), вам потребуется использовать некоторую информацию о базовых объектах в кластере.Если все, что у вас есть, это ссылки на различные объекты без внутренней структуры, это невозможно сделать, так как функция не будет иметь ничего для работы, кроме размера кластера.
Итак, допустим, у вас есть некоторая информацияоб объектах.Например, у вас могут быть их имена.Назовите первые k
буквы имени каждого объекта, префикс объекта .Подсчитайте все различные префиксы в вашем кластере и найдите n
наиболее распространенные.Упорядочите эти n
префиксы в алфавитном порядке и добавьте их друг к другу в указанном порядке.Для разумного выбора k
, n
(который должен зависеть от количества ваших кластеров и типичной длины имени объекта), вы получите желаемый результат - при условии, что в каждом кластере достаточно объектов.
Например, если объекты имеют человеческие имена, попробуйте k = 2;и если у вас есть сотни кластеров, возможно, попробуйте n = 2.
Это, конечно, может быть значительно улучшено путем переназначения имен для достижения более равномерного распределения, обработки случаев, когда два префикса имеют одинаковые частоты, и т. д.