1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
| passat |
1.04.2009 16:02
Сообщение
#1
|
|
Новичок ![]() Группа: Пользователи Сообщений: 32 Пол: Мужской Репутация: 0 |
Помогите еще с одной задачкой.
Имеется последовательность натуральных чисел. Необходимо выполнить N перестановок участков последовательности, где участок задается его началом и концом. Перестановка выполняется в начало последовательности. Т.е. для последовательности из 6 чисел ип трех перестановках 2 4 2 4 4 4 результат должен быть 2 3 4 1 5 6 . Количество чисел и перестановок может быть несколько сот тысяч. Первая идея: список. В связи с чем вопрос: можно ли как-то оптимизировать порядок выполнения перестановок? Либо хотя бы порядок переброски итераторов? Или же существует еще какое-то более интересное решение? |
![]() ![]() |
| volvo |
1.04.2009 18:11
Сообщение
#2
|
|
Гость |
Чтоб можно было оптимизировать, надо знать, что для тебя - НЕоптимизированный вариант. Кстати. Зачем это оптимизировать? Ты не привел никаких временнЫх ограничений, и ограничений по памяти тоже не привел, кстати...
Без оптимизации: однонаправленный список + последовательный поиск элемента с нужным номером + перестановка 4-х указателей при перемещении блока в начало списка. На 100 тысячах элементов и 25 тысячах перестановок отрабатывает за 1.5 секунды. Двунаправленный список будет пожирать больше памяти, но может сэкономить время на нахождение элементов списка, расположенных ближе к его концу, чем к началу... |
| passat |
3.04.2009 17:51
Сообщение
#3
|
|
Новичок ![]() Группа: Пользователи Сообщений: 32 Пол: Мужской Репутация: 0 |
Цитата Чтоб можно было оптимизировать, надо знать, что для тебя - НЕоптимизированный вариант. НЕ оптимизированный вариант очевиден - перестановка участка списка. Выполняется за постоянное время. Недостаток, очевидно, необходимость переброски итераторов на начало и конец переставляемого участка. Смущает простота лобового решения задачи. Цитата Кстати. Зачем это оптимизировать? Ты не привел никаких временнЫх ограничений, и ограничений по памяти тоже не привел, кстати... Если б я их знал, то, очевидно привел бы. Цитата Без оптимизации: однонаправленный список + последовательный поиск элемента с нужным номером + перестановка 4-х указателей при перемещении блока в начало списка. На 100 тысячах элементов и 25 тысячах перестановок отрабатывает за 1.5 секунды. Двунаправленный список будет пожирать больше памяти, но может сэкономить время на нахождение элементов списка, расположенных ближе к его концу, чем к началу... Радует, по крайней мере, что направление мысли было правильным. ??? Т.е. из двунаправленного списка я и исходил. Плюс примитивная оптимизация по месторасположению участка (конец-начало списка). Наверное, возможен анализ по сопоставлению участка с промежуточным итератором... Жаль, что правильность решения можно оценить только после удачной сдачи. |
| passat |
6.04.2009 13:03
Сообщение
#4
|
|
Новичок ![]() Группа: Пользователи Сообщений: 32 Пол: Мужской Репутация: 0 |
Как и опасался, по состоянию на данный момент для 100тыс элементов и перестановок нарушен предел времени выполнения.
Идея. Для длинных списков сделать элементы списка списками. В этом случае по идее необходимо будет выполнять больше операций перестановок участков, но зато резко возрастет скорость переброски итераторов. Как думаете, идея стоит выделки или лучше возиться с оптимизацией стартовой точки, от которой будут перебрасываться итераторы. |
passat Перестановка участков последовательности 1.04.2009 16:02
volvo За счет чего? 6.04.2009 15:07
passat Положим, что количество элементов 10000 и каждый в... 6.04.2009 16:41
passat На линейном списке превышен предел времени исполне... 25.04.2009 14:56
volvo passat, а тебе что, обязательно какая-то нужна? У... 26.04.2009 10:11
passat Компилятор Delphi 7 или Free Pascal. Либо на C++ M... 28.04.2009 10:23
passat Не прошла задачка по времени. А жаль. :(
Видимо, ... 29.04.2009 13:25![]() ![]() |
|
Текстовая версия | 9.12.2025 1:04 |