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

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

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

 
 Ответить  Открыть новую тему 
> Двусвязный Кольцевой Неупорядоченный список (исключение узла), Помогите пожалуйста исправить
Everveit
сообщение 13.05.2007 18:45
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 15
Пол: Женский

Репутация: -  0  +


Мне нужно исключить к-ый узел. Что здесь не правильно?

Procedure DeleteNode(var h:Dlist; k:integer);
var q:dlist;
i:integer;
begin
  i:=1;
  writeln ('vvedite nomer k:');
  readln (k);
  if h=nil then writeln ('spisok pust')
  else
  begin
	 q:=h^.next;
	 while (q<>h) and (i<k) do
	 begin
	   q:=q^.next;
	   inc(i);
	   end;
	 if i<>k then
	 writeln ('nepravilniy nomer')
	 else
	 if q^.next=q then
	  begin
	  h:=nil;
	  dispose(q);
	  end
	 else
	 begin
	 if q=h then
	 p:=p^.next;
	 q^.prev^.next:=q^.next;
	 q^.next^.prev:=q^.prev;
	 dispose (q);
	 end;
	 end;
end;


Сообщение отредактировано: volvo - 12.05.2010 21:00
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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

 

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