О серии
Во-первых, вы можете относиться к этому, как к любому другому вызову для игры в гольф, и отвечать на него, не беспокоясь о серии вообще. Тем не менее, существует таблица лидеров по всем задачам. Вы можете найти таблицу лидеров вместе с дополнительной информацией о серии в первом посте .
Несмотря на то, что у меня есть ряд идей для этой серии, будущие проблемы еще не заложены. Если у вас есть какие-либо предложения, пожалуйста, сообщите мне об этом в соответствующей песочнице .
Отверстие 4: парадокс Бертран
Бертрана парадокс интересная проблема, которая показывает , как различные методы для выбора случайных аккордов в круге может дать различные распределения аккордов, их середин и их длину.
В этой задаче вы должны генерировать случайные аккорды единичного круга, используя «правильный» метод, то есть тот, который производит распределение аккордов, которое является инвариантным при масштабировании и трансляции. В связанной статье в Википедии «Метод 2» является таким методом.
Вот точные правила:
- Вы должны взять одно положительное целое число,
N
которое указывает, сколько аккордов должно быть возвращено. На выходе должен быть списокN
аккордов, каждый из которых указан в виде двух точек на единичной окружности, заданных их полярным углом в радианах. - Ваш код должен иметь возможность возвращать как минимум 2 20 различных значений для каждого из двух углов . Если имеющийся у вас ГСЧ имеет меньший диапазон, вы должны сначала создать ГСЧ с достаточно большим диапазоном поверх встроенного, либо вы должны реализовать свой собственный подходящий ГСЧ . Эта страница может быть полезна для этого.
- Распределение аккордов должно быть неотличимо от распределения, произведенного «Методом 2» в связанной статье Википедии. Если вы применяете другой алгоритм выбора аккордов, пожалуйста, приложите подтверждение правильности. Какой бы алгоритм вы ни выбрали для реализации, он теоретически должен быть способен генерировать любой действительный аккорд в единичном круге (за исключением ограничений базовых типов данных PRNG или ограниченной точности).
- Ваша реализация должна использовать и возвращать либо числа с плавающей запятой (шириной не менее 32 бит), либо числа с фиксированной запятой (шириной не менее 24 бит), и все арифметические операции должны быть точными в пределах не более 16 ulp .
Вы можете написать полную программу или функцию и получить ввод через STDIN (или ближайшую альтернативу), аргумент командной строки или аргумент функции и произвести вывод через STDOUT (или ближайшую альтернативу), возвращаемое значение функции или параметр функции (out).
Вывод может быть в любом удобном формате списка или строки, если отдельные числа четко различимы, а их общее число всегда четное.
Это код гольф, поэтому выигрывает самое короткое представление (в байтах). И, конечно же, самая короткая заявка на пользователя также войдет в общую таблицу лидеров серии.
Визуализация
Вы можете использовать следующий фрагмент для рендеринга сгенерированных строк и проверки их распределения. Просто вставьте список пар углов в текстовую область. Фрагмент должен быть в состоянии обрабатывать практически любой формат списка, если числа являются простыми десятичными числами (без научных обозначений). Я рекомендую вам использовать не менее 1000 строк, чтобы получить хорошее представление о распределении. Я также предоставил некоторые примеры данных для различных методов, представленных в статье ниже.
Пример данных, сгенерированных методом 1.
Пример данных, сгенерированных по методу 2.
Пример данных, сгенерированных по методу 3.
Leaderboard
Первый пост серии генерирует таблицу лидеров.
Чтобы убедиться, что ваши ответы отображаются, начните каждый ответ с заголовка, используя следующий шаблон уценки:
# Language Name, N bytes
где N
размер вашего представления. Если вы улучшите свой счет, вы можете сохранить старые результаты в заголовке, вычеркнув их. Например:
# Ruby, <s>104</s> <s>101</s> 96 bytes
(Язык в настоящее время не отображается, но фрагмент требует и анализирует его, и я могу добавить таблицу лидеров по языкам в будущем.)
Pyth,
252322 байтаПорт ответа C ++ 11 на rcrmn. Это мое первое использование Pyth, и мне было очень весело!
23-байтовая версия:
Сократите байт, изменив программу на использование складок + сумм и установив J в кортеж, удалив K.
Оригинал:
Отрежьте 2 байта благодаря @orlp.
Объяснение:
источник
*2_
же, какy_
. ПеременнаяZ
изначально равна 0, поэтому вы можете удалить пробел.tO0 4
, написав.tOZ4
.,+JK-JK
y
и забыл оZ
. Исправлена; Благодарность!Юлия, 48 байт
При этом используется алгоритм метода 2, как и большинство ответов на данный момент. Он создает лямбда-функцию, которая принимает целочисленный ввод и возвращает массив nx 2. Чтобы назвать его, дайте ему имя, например
f=n->...
.Ungolfed + объяснение:
Мне очень нравится, как выглядят визуализации, поэтому я включу одну. Это результат
f(1000)
.источник
Pyth, 22 байта
Порт ответа C ++.
У меня было еще одно 23-байтовое решение(теперь 22!), Но это была почти копия точного ответа @ kirbyfan64sos с оптимизацией, поэтому мне пришлось немного нестандартно подумать и творчески (ab) использовать оператор свертывания.Обратите внимание, что это не работает сейчас из-за ошибки в операторе сгиба после введения
reduce2
. Я помещаю запрос на получение.Для справки это было мое другое решение, которое работает таким же образом:
VQKy*.nZOZJ.tOZ4,+KJ-KJ
источник
IDL, 65 байт
Очевидно, это тот же алгоритм, что и у @rcrmn, хотя я вывел его независимо, прежде чем читать их ответ.
Функция randomu в IDL использует Mersenne Twister с периодом 2 19937 с -1.
РЕДАКТИРОВАТЬ: я провел 1000 аккордов через визуализатор выше, вот скриншот результата:
источник
C ++ 11, 214 байтов
Так что это прямая реализация правильного алгоритма со страницы википедии. Главная проблема здесь, в гольфе, это оооочень длинные имена, которые есть у классов случайных генераторов. Но, в отличие от хорошего старого, он, по крайней мере, правильно унифицирован.
Объяснение:
источник
M_PI_2
выглядит подозрительно. Я думаю, что это должно быть 1 вместо.APL, 46 байт
Моя первая программа APL! Конечно, это может быть значительно улучшено (поскольку мое общее понимание APL отсутствует), поэтому любые предложения будут фантастическими. Это создает функцию,
f
которая принимает целое число в качестве входных данных, вычисляет пары точек хорды, используя метод 2, и печатает каждую пару, разделенную новой строкой.Вы можете попробовать это онлайн !
Объяснение:
Примечание: мое предыдущее 19-байтовое решение было недопустимым, поскольку оно вернуло (x, y), а не (x + y, xy). Грусть изобилует.
источник
Java, 114 байт
Базовая реализация в Java. Используйте в качестве лямбда-выражения.
Пример использования
источник
Math
где-нибудь? Или что-то? (Я не программист на Java)Math
показывает. Что говорит мета об использовании кода для генерации другого кода для решения проблемы?Рубин, 72 байта
Мой первый гольф здесь! Я использовал тот же код, что и все, я надеюсь, что все в порядке
источник
Ява, 115
123Это в основном то же самое, что и большинство других, но мне нужна оценка Java для этой дыры, так что вот так:
1000 образцов аккордов можно найти на pastebin , вот первые пять из одного запуска:
источник
CJam,
2422 байтаПодобно другим алгоритмам, здесь есть версия в CJam.
Ввод 1000 производит распределение как:
Как это устроено
Алгоритм просто
x = 2 * Pi * rand(); print [x, x + 2 * acos(rand())]
Обновление : 2 байта сохранены благодаря Мартину!
Попробуй здесь
источник
Python 3,
144117 байт(спасибо Blckknght за
lambda
указатель)Используя тот же метод, что и другие:
Из документации Python:
Выход
И так далее.
Визуализация
источник
f=lambda n:[(x,x+2*m.acos(r()))for x in(2*m.pi*r()for _ in range(n))]
Perl, 60
источник
R
60565349 байтДополнительные 4 байта благодаря @JayCe и превращению его в функцию.
Используя ту же базовую формулу, что и остальные. R по умолчанию использует метод Мерсенна-Твистера, но можно установить и другие. Выводит разделенный пробелами список.
Попробуйте онлайн!
источник
SmileBASIC, 62 байта
источник