Ребята, если кому-то будет интересна эта тема, вот мои наработки.
Пока, вроде, получилось. Правда, есть ограничение на генерируемые размещения.
Собственно, заметка о том, как превратить размещения в перестановки.
Все алгоритмы, которые я встречал в Интернете на ключевые слова "перестановки и permutations" мне показались сложными для понимания. Заодно отталкивает использование рекурсии. Работая над другим скриптом, пришел к следующему выводу.
Чтобы получить все перестановки, которые, как известно, равны факториалу n!,
сначала надо получить все размещения с повторениями. Мной был найден такой скрипт и несколько переделан, взят с hashcode, автора не помню.
Мы генерируем все размещения в данном случае 4-х элементов - abcd. Для этого используется цикл до 4 в степени 4 (все размещения с повторением). Данные преобразуются в четверичную систему, дописываются нули слева. Затем с помощью strtr преобразование в abcd. Вот, с первым скриптом все.
1. dcc0 - 06 Сентября, 2014 - 17:05:11 - перейти к сообщению
А дальше?! Надо удалить из всех размещений каждую строку, в который символ повторяется. Второй скрипт читает из файла f.txt построчно, проверяет количество одного символа в строке и записывает в промежуточный файл только те строки, в которых символ один. Когда цикл переберет все записи на одну букву, подставит другую. Первый цикл - перебора массива - будет иметь столько итераций, сколько всего букв в алфавите, т.е. n. Иначе говоря, есть abcd - 4 буквы, у цикла перебора массива будет 4 итерации.
Промежуточные вычисления записываются в дополнительный файлы, потом файлы удаляются и переименовываются.
PHP:
скопировать код в буфер обмена
скопировать код в буфер обмена
- <?PHP
- /*Входной алфавит*/
- /*Количество символов*/
- $n=3;
- /*Перебор. Сброс на последнем символе*/
- foreach($arr as $k => $v) {
- if($k==$n) {
- break;
- }
- /*Читаем из файла по строчно*/
- /*Если символ встречается 1 раз пишем в другой файл. Переменная - шаблон
- подставляется из цикла сверху*/
- if($c==1) {
- }
- }
- /*Переименовываем все файлы, удалем промежуточные*/
- }
- ?>