Проблема Иосифа - Josephus problem

В Информатика и математика, то Проблема Иосифа (или же Перестановка Иосифа) - теоретическая проблема, относящаяся к определенному счетная игра.

Рисунок последовательности задач Иосифа Флавия для 500 человек со значением пропуска 6. По горизонтальной оси отложен номер человека. Вертикальная ось (сверху вниз) - время (номер цикла). Живой человек изображается зеленым, мертвый - черным.[1]

Люди стоят в круг ожидая исполнения. Подсчет начинается в указанной точке круга и продолжается по кругу в указанном направлении. После того, как указанное количество людей пропущено, выполняется следующий человек. Процедура повторяется с оставшимися людьми, начиная со следующего человека, идя в том же направлении и пропуская такое же количество людей, пока не останется только один человек, и его освободят.

Проблема - учитывая количество людей, начальную точку, направление и количество, которое нужно пропустить - состоит в том, чтобы выбрать позицию в начальном круге, чтобы избежать казни.

История

Проблема названа в честь Флавий Иосиф, еврейский историк, живший в I веке. Согласно описанию Иосифа Флавия осада Йодфата, он и его 40 солдат были пойманы в пещере Римские солдаты. Они предпочли самоубийство поимке и остановились на серийном методе самоубийства путем жеребьевки. Иосиф заявляет, что по счастливой случайности или, возможно, по воле Божьей, он и еще один человек оставались до конца и сдались римлянам, вместо того чтобы убить себя. Это история, данная в книге 3, главе 8, части 7 Иосифа Флавия. Еврейская война (написание себя от третьего лица ):

Однако в этом крайнем бедственном положении он не лишился своей обычной проницательности; но, доверившись провидению Божьему, он подверг свою жизнь опасности [следующим образом]: «А теперь, - сказал он, - раз уж между вами решено, что вы умрете, давайте, давайте совершим наше общее смерть к определению по жребию. Тот, кому выпадет жребий первым, пусть будет убит тем, у кого второй жребий, и таким образом удача будет распространяться через всех нас; и никто из нас не погибнет от своей собственной правой руки, ибо было бы несправедливо, если бы, когда остальные ушли, кто-то покаялся и спасся ». Это предложение показалось им очень справедливым; и когда он уговорил их определить это дело по жребию, он также вытянул один из жребий для себя. Тот, у кого был первый жребий, обнажил шею тому, у кого был следующий, предполагая, что генерал умрет среди них немедленно; ибо они думали, что смерть, если Иосиф мог умереть с ними, слаще жизни; тем не менее, он остался с другим до последнего, должны ли мы сказать, что это произошло случайно или по провидению Божьему. И так как он очень не желал, чтобы его осудила жребий, или, если бы он был оставлен до последнего, пропитать свою правую руку кровью своих соотечественников, он убедил его поверить в свою верность ему и жить как и он сам.[2]

Детали механизма, использованного в этом подвиге, довольно расплывчаты. По словам Джеймса Дауди и Майкла Мэйса,[3] в 1612 г. Клод Гаспар Баше де Мезириак предложил особый механизм расстановки мужчин по кругу и подсчета троек, чтобы определить порядок исключения.[4] Эта история часто повторяется, и конкретные детали значительно различаются от источника к источнику. Например, Израиль Натан Херштейн и Ирвинг Каплански (1974) Иосиф Флавий и 39 товарищей встают в круг, а каждый седьмой исключен.[5] Историю проблемы можно найти в книге С. Л. Забелла. Письмо редактору из Ежеквартальный отчет Фибоначчи.[6]

У Иосифа был сообщник; тогда проблема заключалась в том, чтобы найти места двух последних оставшихся в живых (чей заговор обеспечил их выживание). Утверждается, что он поставил себя и другого мужчину на 31-е и 16-е места соответственно.[7]

Варианты и обобщения

Средневековая версия проблемы Иосифа включает 15 турок и 15 христиан на борту корабля во время шторма, который затонет, если половина пассажиров не будет выброшена за борт. Все 30 человек стоят в кругу, и каждого девятого бросить в море. Где должны стоять христиане, чтобы бросить только турок?[8] В других версиях роли турок и христиан меняются местами.

В Конкретная математика: основа компьютерных наук, Грэм, Кнут и Паташник описывают и изучают «стандартный» вариант:[9] Определите, где стоит последний выживший, если есть п люди, чтобы начать и каждый второй человек (k = 2 ниже) исключается.

Обобщение этой проблемы состоит в следующем. Мы предполагаем, что каждый мый человек будет казнен из размерной группы п, в которой п-й человек - оставшийся в живых. Если есть добавление Икс людей в круг, то оставшийся в живых оказывается в п + mx-я позиция, если она меньше или равна п + Икс. Если Икс наименьшее значение, для которого (п + mx) > (п + Икс), то оставшийся в живых занимает позицию (п + mx) − (п + Икс).[10]

Решение

В следующих, обозначает количество людей в начальном круге, а обозначает счет для каждого шага, то есть люди пропускаются и -го выполнено. Люди в круге пронумерованы от к .

k = 2

Мы явно решаем проблему, когда будет убит каждый второй человек, т.е. . (В более общем случае , мы намечаем решение ниже.) Мы выражаем решение рекурсивно. Позволять обозначают положение выжившего, когда изначально люди (и В первый раз по кругу умирают все четные люди; во второй раз по кругу умирает новый 2-й человек, затем новый 4-й и т. Д .; как будто не было первого раза по кругу.

Если исходное количество людей было четным, то человек в должности во второй раз по кругу был изначально на позиции (для каждого выбора ). Позволять . Человек в Кто теперь выживет, изначально занимал позицию . Это дает нам повторение

Если первоначальное количество людей было нечетным, то мы думаем, что человек 1 умирает в конце первого оборота круга. Опять же, во второй раз по кругу умирает новый 2-й человек, затем новый 4-й и т. Д. В этом случае человек, занимающий позицию изначально был на позиции . Это дает нам повторение

Когда мы заносим в таблицу значения и мы видим узор: OEISA006257

12345678910111213141516
1131357135791113151

Это говорит о том, что - возрастающая нечетная последовательность, которая перезапускается с всякий раз, когда индекс п степень 2, поэтому, если мы выберем м и л так что и , тогда .Ясно, что значения в таблице удовлетворяют этому уравнению. Или мы можем думать, что после люди мертвы есть только люди и мы идем в й человек. Он должен быть выжившим. Так . Ниже мы дадим доказательство по индукции.

Теорема: Если и , тогда .

Доказательство: Мы используем сильная индукция на . Базовый случай верно. Рассмотрим отдельно случаи, когда даже и когда странно.

Если ровно, тогда выберите и такой, что и . Обратите внимание, что .У нас есть , где второе равенство следует из предположения индукции.

Если нечетно, тогда выберите и такой, что и . Обратите внимание, что .У нас есть , где второе равенство следует из предположения индукции. Это завершает доказательство.

Мы можем решить чтобы получить явное выражение для :

Самая элегантная форма ответа включает двоичное представление размера : может быть получен однобитным циклическим сдвигом влево сам. Если мы представляем в двоичном виде как , то решение дается формулой . Доказательство этого следует из представления в качестве или из приведенного выше выражения для .

Выполнение: Если n обозначает количество людей, безопасное положение задается функцией ,куда и .

Теперь, если мы представим число в двоичном формате, первый бит обозначает а остальные биты будут обозначать . Например, когда n = 41, его двоичное представление будет

п = 1 0 1 0 0 1

2м = 1 0 0 0 0 0

л = 0 1 0 0 1

    /**	 * * @param n количество людей, стоящих в круге* @ вернуть безопасную позицию, кто переживет казнь * f (N) = 2L + 1, где N = 2 ^ M + L и 0 <= L <2 ^ M	 */	общественный int getSafePosition(int п) {		// находим значение L для уравнения		int valueOfL = п - Целое число.highOneBit(п);		int safePosition = 2 * valueOfL  + 1;				возвращаться safePosition;	}

Побитовое

Самый простой способ найти безопасную позицию - использовать побитовые операторы. В этом подходе сдвиг самого старшего бита набора n в младший бит вернет безопасную позицию.[11] Введите положительное целое число.

п = 1 0 1 0 0 1

п = 0 1 0 0 1 1

    /**	 * * @param n (41) количество людей, стоящих в круге* @ вернуть безопасную позицию, кто переживет казнь * ~ Целое число.highestOneBit (n * 2)* Умножьте n на 2, получите первый установленный бит и возьмите его дополнение* ((n << 1) | 1)* Left Shift n и переворачивание последнего бита* ~ Integer.highestOneBit (n * 2) & ((n << 1) | 1) * Побитовое И для копирования битов существует в обоих операндах.	 */	общественный int getSafePosition(int п) {		возвращаться ~Целое число.highOneBit(п*2) & ((п<<1) | 1);	}

k = 3

В 1997 году Лоренц Хальбайзен и Норберт Хунгербюлер обнаружили закрытый бланк для дела. . Они показали, что существует некая постоянная

которые могут быть вычислены с произвольной точностью. Учитывая эту константу, выберите быть наибольшим целым таким, что (это будет либо или же ). Тогда последний выживший

если бы мы собрали еще

для всех .

В качестве примера расчета Хальбайзен и Хунгербюлер приводят (что на самом деле является исходной формулировкой проблемы Иосифа Флавия). Они вычисляют:

и поэтому
(обратите внимание, что мы округлили в меньшую сторону)

Мы можем убедиться в этом, глядя на каждый последующий проход чисел через :

Общий случай

Динамическое программирование используется для решения этой проблемы в общем случае, выполняя первый шаг, а затем используя решение оставшейся проблемы. Когда индекс начинается с единицы, то человек в смены от первого лица на позиции , где n - общее количество человек. Позволять Обозначьте положение выжившего. После -й человек убит, остается круг , и мы начинаем следующий счет с человека, чье число в исходной задаче было . Положение выжившего в оставшемся круге будет если мы начнем считать с ; сдвигая это, чтобы учесть тот факт, что мы начинаем с дает повторение[12]

которая принимает более простой вид

если пронумеровать позиции из к вместо.

Этот подход имеет Продолжительность , но для маленьких и большой есть другой подход. Второй подход также использует динамическое программирование, но имеет время выполнения. . Он основан на рассмотрении убийства k-й, 2k-й, ..., -й человек как на один шаг, потом меняю нумерацию.[нужна цитата ]

Этот улучшенный подход принимает форму

Примечания

  1. ^ Проблема Иосифа. Решение задачи Проблема Иосифа в Код Розетты, написано на языке Frmulæ. Вики Сообщества. Проверено 19 сентября 2019 года.
  2. ^ Флавий Иосиф, Войны евреев III. 8. 7. (Перевод Уильяма Уистона).
  3. ^ Дауди и Мэйс 1989, п. 125
  4. ^ Баше, К. Г. (1612). Problemes Plaisants ed Delectables qui se font par les Nombres. п. 174.
  5. ^ Herstein, I. N .; Капланский, И. (1974). Вопросы математические. Харпер и Роу. стр.121–126.
  6. ^ Забелл, С. Л. (1976). "Письмо редактору". Ежеквартальный отчет Фибоначчи. 14: 48, 51.
  7. ^ Роуз Болл, У. У. (1896). Математические развлечения и эссе (2-е изд.). Макмиллан.
  8. ^ Ньюман, Дж. Р. (1988). Мир математики. 4. Темпус. С. 2403–2405.
  9. ^ Graham, R.L .; Кнут, Д. Э.; Паташник, О. (1989). Конкретная математика: основа компьютерных наук. Эддисон Уэсли. п. 8. ISBN  978-0-201-14236-5.
  10. ^ Робинсон, У. Дж. (1960). «Проблема Иосифа». Математический вестник. 44 (347): 47–52. Дои:10.2307/3608532. JSTOR  3608532.
  11. ^ «Проблема Иосифа с использованием побитовой операции (Java)». GitHub. 7 января 2018 г.. Получено 7 января, 2018.
  12. ^ Пак, Чан Ву; Тейшейра, Рикардо (2018). «Серийная казнь Иосифа Проблема». Корейский J. Math. 26 (1): 1–7. Дои:10.11568 / kjm.2018.26.1.1.

Рекомендации

внешняя ссылка