Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Центр помощи > [Pascal]Двусвязный кольцевой список


Автор: Fuaran8989 12.5.2008, 19:29
[Pascal]Двусвязный кольцевой упорядоченный список(модули)
нужно написать следующие процедуры:

-перемещение по списку(стрелки)

-включение нового узла(Ins)

-Исключение узла(del)

-очистка списка(F8)

-Сохранение содержимого списка в файле(F2)

-Чтение содержимого списка из файла(F3)

-Выход из программы(Esc)

Автор: Wedafl 15.5.2008, 16:36
Вам обязательно паскаль? Дельфи не подойдет?

Автор: Fuaran8989 16.5.2008, 19:46
да к сожалению паскаль но я думаю если дельфи то там сильные отличия? попытаюсь переправить или сдать в дельфи..

Автор: Fuaran8989 19.5.2008, 17:24
ну так что?

Автор: Fuaran8989 25.5.2008, 15:28
хелп плз! сессия горит!!

Автор: lemuriaIATE 26.5.2008, 00:16
посмотри http://forum.pascal.net.ru/index.php?act=Search&CODE=show&searchid=90e8d3a25f1667557b7051121aecc726&search_in=posts&result_type=topics&highlite=%2B%E4%E2%F3%F1%E2%FF%E7%ED%FB%E9+%EA%EE%EB%FC%F6%E5%E2%EE%E9

Автор: Fuaran8989 26.5.2008, 17:29
вот пара процедур. требуются остальные особенно с перемещением по списку не представляю как делать

Код
procedure AddNewNode(var p:Dlist; info:integer);
var
  q, pp:Dlist;
  i, k:integer;

begin
  if p = nil then begin
    New(q);
    writeln ('vvedite info:');
    readln(info);
    q^.info :=info;
    q^.next := q;
    q^.prev := q;
    p := q; 
  end

  else begin
    writeln('vvedite k:');
    readln(k);

    q := p^.next; i := 1;
    if p = q then dec(i);
    while (q <> p) and (i < k - 1) do begin
      q := q^.next;
      i := i + 1;
    end;

    if i <> k - 1 then writeln ('nepravilniy nomer')
    else begin
      new(pp);
      writeln('vvedite info:');
      readln(info);
      pp^.next := q^.next;
      pp^.prev := q;
      pp^.next^.prev := pp;
      q^.next := pp;
      pp^.info := info;
    end;
  end;
end;


procedure DeleteNode(var p:Dlist);
var
  q: dlist;
  i, k: integer;
begin
  if p = nil then writeln ('spisok pust')
  else begin

    i := 1;
    writeln ('vvedite k:');
    readln (k);

    if k > 1 then begin

      q := p^.next;
      while (q <> p) and (i<>k-1) do begin
        q := q^.next;
        inc(i);
      end;

    end
    else begin { k = 1 }
      i := 0; q := p;
    end;

    if i <> k-1 then writeln ('uzel ne naiden')
    else
      if q^.next = q then begin
        p := nil;
        dispose(q);
      end
    else begin
      if q = p then p := p^.next;

      q^.prev^.next := q^.next;
      q^.next^.prev := q^.prev;
      dispose (q);
    end;
  end;
end;

Автор: DDV 26.5.2008, 17:52
Посмотри по форуму я эту прогу где-то видел.

Автор: Fuaran8989 26.5.2008, 18:18
Нашел похожие но для линейного списка...

Автор: Wedafl 27.5.2008, 05:09
Вот недавно делал http://dassm.narod.ru/Relise/DCList.rar
Смотрите файл untDCList.pas достаточно подробно прокоментированно, многое должно работать и на паскале.
Основное отличие вашего списка будет в том что у него нет указателя на хвост( fLast в моем исходнике), потому что у последнего в списке элемента(узла) указатель на следующий элемент указывает на голову (в моем исходнике fFirst).

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)