IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

 
 Ответить  Открыть новую тему 
> ДВУСВЯЗНЫЕ СПИСКИ: переместить элемент
Владик
сообщение 23.12.2005 11:01
Сообщение #1


Гость






Помогите решить задачку!
Дан двусвязный список и указатель Р0 на один из его элементов,
переместить P0 на К(>0) позиций назад(т.е. через К элементов).
Если К больше числа элементов списка, стоящих перед Р0 то переместить в начало дв. списка. Операции выделения, освобождения памяти не использовать.
 К началу страницы 
+ Ответить 
volvo
сообщение 23.12.2005 11:34
Сообщение #2


Гость






...
k := 20;
move_to := p;

while (move_to <> nil) and (k > 0) do begin
move_to := move_to^.prev; dec(k);
end;

if p^.prev <> nil then p^.prev^.next := p^.next;
if p^.next <> nil then p^.next^.prev := p^.prev;

if move_to = nil then begin
move_to := first; first := p
end;
if move_to^.prev <> nil then
move_to^.prev^.next := p;
p^.prev := move_to^.prev;

if move_to^.next <> nil then
move_to^.next^.prev := p;
p^.next := move_to;
...
 К началу страницы 
+ Ответить 
Гость
сообщение 24.12.2005 8:36
Сообщение #3


Гость






спасибо smile.gif
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 20.07.2025 1:53
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"