Сочетания: различия между версиями
СВ (обсуждение | вклад) |
СВ (обсуждение | вклад) |
||
Строка 10: | Строка 10: | ||
{{Пример | {{Пример | ||
|num=1 | |num=1 | ||
| | |content=Предположим, из <math>n</math> участников спортивного клуба на соревнования должны поехать какие-то <math>k</math>. | ||
Тогда имеется <math>C_n^k</math> различных возможности собрать команду. | Тогда имеется <math>C_n^k</math> различных возможности собрать команду. | ||
}} | }} | ||
{{Пример | {{Пример | ||
|num=2 | |num=2 | ||
| | |content= Пусть <math>S = \{1,2,3\}</math>. Тогда <math>\{1,2\}</math>, <math>\{1,3\}</math>, <math>\{2,3\}</math> {{---}} все возможные cочетания из трех элементов по два. | ||
}} | }} | ||
{{Утверждение | {{Утверждение | ||
Строка 62: | Строка 62: | ||
{{Пример | {{Пример | ||
|num=1 | |num=1 | ||
| | |content=Рассмотрим, как работает алгоритм для <math>n=5</math> и <math>k=3</math>. | ||
# Сначала <math>x = (x_1, x_2, x_3) = (1,2,3)</math>. | # Сначала <math>x = (x_1, x_2, x_3) = (1,2,3)</math>. | ||
# Увеличиваем <math>x_3</math>: <math>x = (1,2,4)</math>. | # Увеличиваем <math>x_3</math>: <math>x = (1,2,4)</math>. |
Текущая версия на 16:26, 4 ноября 2021
Не умаляя общности, можно называть сочетанием из [math]\displaystyle{ n }[/math] элементов по [math]\displaystyle{ k }[/math] неупорядоченный набор из [math]\displaystyle{ k }[/math] различных чисел, принадлежащих множеству [math]\displaystyle{ \{1, ..., n\} }[/math].
Количество различных сочетаний из [math]\displaystyle{ n }[/math] по [math]\displaystyle{ k }[/math] обозначают [math]\displaystyle{ C_n^k }[/math] или [math]\displaystyle{ \binom{n}{k} }[/math].
Действительно, каждому сочетанию из [math]\displaystyle{ n }[/math] по [math]\displaystyle{ k }[/math] соответствует [math]\displaystyle{ k! }[/math] различных размещений из [math]\displaystyle{ n }[/math] по [math]\displaystyle{ k }[/math] с различным порядком следования элементов. Тогда [math]\displaystyle{ \binom{n}{k} = \frac{A_n^k}{k!} = \frac{n!}{k!(n-k)!} }[/math].
Свойства числа сочетаний
[math]\displaystyle{ \binom{n}{k}\cdot\binom{k}{l} = \binom{n}{l}\cdot \binom{n-l}{k-l}. }[/math]
Действительно, [math]\displaystyle{ \binom{n}{k}\cdot\binom{k}{l}= \frac{n!}{k!(n-k)!}\cdot\frac{k!}{l!(k-l)!} \cdot \frac{(n-l)!}{(n-l)!}= \frac{n!}{l!(n-l)!}\cdot\frac{(n-l)!}{(k-l)!(n-k)!} = \binom{n}{l}\cdot \binom{n-l}{k-l}. }[/math]
Интуитивно формулу можно описать как разбиение множества из [math]\displaystyle{ n }[/math] элементов на три подмножества мощностей [math]\displaystyle{ l }[/math], [math]\displaystyle{ k-l }[/math], [math]\displaystyle{ n-k }[/math] соответственно. Левая часть равенства описывает выбор сначала [math]\displaystyle{ k }[/math] элементов из [math]\displaystyle{ n }[/math], а затем [math]\displaystyle{ l }[/math] элементов из выбранных [math]\displaystyle{ k }[/math]. Получим все варианты разбиения исходного множества на три подмножества указанных мощностей.
Правая часть равенства соответствует выбору сначала [math]\displaystyle{ l }[/math] элементов из [math]\displaystyle{ n }[/math], а затем [math]\displaystyle{ k-l }[/math] элементов из оставшихся [math]\displaystyle{ n-l }[/math]. Получим те же варианты подмножеств.
Алгоритм перебора сочетаний
Пусть [math]\displaystyle{ x_1, x_2, ..., x_k }[/math] — числа из множества [math]\displaystyle{ \{1,2,...,n\} }[/math], вошедшие в сочетание, причем [math]\displaystyle{ x_1 \lt x_2 \lt ... \lt x_k }[/math].
Пусть в начальный момент времени сочетание состоит из первых [math]\displaystyle{ k }[/math] чисел: [math]\displaystyle{ x_i = i, i=\overline{1,k} }[/math].
На каждом шаге будем просматривать вектор [math]\displaystyle{ (x_1, x_2, ..., x_k) }[/math], начиная с [math]\displaystyle{ x_k }[/math], и искать первую такую компоненту [math]\displaystyle{ x_i }[/math], которую можно увеличить (нельзя увеличить [math]\displaystyle{ x_k }[/math], если он равен [math]\displaystyle{ n }[/math]; [math]\displaystyle{ x_{k-1} }[/math], если он равен [math]\displaystyle{ n-1 }[/math] и так далее).
Если такой компоненты не найдется, алгоритм завершает свою работу. В противном случае, пусть [math]\displaystyle{ i }[/math] — такое наибольшее число, что [math]\displaystyle{ x_i \lt n-k+i }[/math]. Увеличим [math]\displaystyle{ x_i }[/math] на единицу, а для всех [math]\displaystyle{ x_t, t=\overline{i+1,k} }[/math], присваиваем значения [math]\displaystyle{ x_t = x_i+(t-i) }[/math]. Повторяем процесс нужное число раз.
Пример
- Сначала [math]\displaystyle{ x = (x_1, x_2, x_3) = (1,2,3) }[/math].
- Увеличиваем [math]\displaystyle{ x_3 }[/math]: [math]\displaystyle{ x = (1,2,4) }[/math].
- Увеличиваем [math]\displaystyle{ x_3 }[/math]: [math]\displaystyle{ x = (1,2,5) }[/math].
- [math]\displaystyle{ x_3 }[/math] больше увеличить нельзя. Увеличиваем [math]\displaystyle{ x_2 }[/math] и переназначаем значение [math]\displaystyle{ x_3 }[/math]: [math]\displaystyle{ x = (1,3,4) }[/math].
- [math]\displaystyle{ x = (1,3,5) }[/math]
- [math]\displaystyle{ x = (1,4,5) }[/math]
- [math]\displaystyle{ x = (2,3,4) }[/math]
- [math]\displaystyle{ x = (2,3,5) }[/math]
- [math]\displaystyle{ x = (2,4,5) }[/math]
- [math]\displaystyle{ x = (3,4,5) }[/math]