Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.06.27;
Скачать: CL | DM;

Вниз

Алгоритм нахождения всех перестановок   Найти похожие ветки 

 
Walkie Talkie   (2004-06-10 16:11) [0]

Блин, чё-то сообразить никак не могу... парюсь с этим рекурсивом...

В общем есть такое: obj: array[1..10] of string;

а result:=obj[1]+obj[2]+...+obj[10];

Вот нужно создать прогу, которая "перетасовывала" этот obj, чтобы получить все возможные перестановки... их N!... в данном случае 10!
реализация нужна для любого количеста элементов...


 
MBo ©   (2004-06-10 16:33) [1]

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


 
Walkie Talkie   (2004-06-10 19:56) [2]


> раз тебе нужно реализовать задачу именно рекурсивно

а разве можно по-другому?

PS Хотелось бы более практический совет...


 
GuAV ©   (2004-06-10 22:11) [3]

похожую задачку уже решал:
http://delphimaster.net/view/1-1086250968/


 
Aldor ©   (2004-06-10 22:21) [4]

Во-первых www.google.com + "permutation generation"

 Во-вторых, Кнут, первый том, описан не один оригальный способ, в частности http://acm.uva.es/p/v100/10063.html.

       Удачи!


 
default ©   (2004-06-10 22:24) [5]

http://algolist.manual.ru/maths/combinat/permutations.php


 
default ©   (2004-06-10 22:28) [6]

Aldor ©   (10.06.04 22:21) [4]
у Кнута по-моему больше теор-ки этот момент разобран...могу ошибаться


 
Aldor ©   (2004-06-11 00:05) [7]

default ©   (10.06.04 22:28) [6]
у Кнута по-моему больше теор-ки этот момент разобран...

 Не могу сказать точно, под рукой сейчас нет, но даже если там не приведен код на mix-assembler"е (что, скорее всего автору поста не понадобится), то там алгроитм описан словесно - для таких простых алгоритмов этого, мне кажется, вполне достаточно.


 
Walkie Talkie   (2004-06-11 00:27) [8]


> http://algolist.manual.ru/maths/combinat/permutations.php


Как это я не заметил спасибо... хотя не совсем то, но я уже адаптировал.

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



Страницы: 1 вся ветка

Текущий архив: 2004.06.27;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.058 c
3-1086259092
Shadow Of Templar
2004-06-03 14:38
2004.06.27
Проблема с внешними файлами в FireBird


11-1075723164
Solik
2004-02-02 14:59
2004.06.27
Максимизация окна


3-1086094755
Balu
2004-06-01 16:59
2004.06.27
Вставка новой записи в базу


1-1086769085
Snip
2004-06-09 12:18
2004.06.27
Hint в TreeView


4-1084875468
OlegM
2004-05-18 14:17
2004.06.27
Как узнать минимизировано ли окно или нет?