Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Turbo Pascal] Добавить элемент в конец очереди 
:(
    Опции темы
deimond
Дата 8.4.2011, 21:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 3.4.2011

Репутация: нет
Всего: нет



Помогите с задачкой.

Дано число D и указатели P1 и P2 на начало и конец очереди (если очередь является пустой, то P1 = P2 = nil). Добавить элемент со значением D в конец очереди и вывести новые адреса начала и конца очереди.

Это сообщение отредактировал(а) deimond - 8.4.2011, 21:30
PM MAIL   Вверх
deimond
Дата 24.4.2011, 21:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 3.4.2011

Репутация: нет
Всего: нет



Помогите, пожалуйста, с реализацией задачи
PM MAIL   Вверх
v4v4n
Дата 25.4.2011, 15:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 45
Регистрация: 26.9.2008

Репутация: 2
Всего: 4



если
Код

Type
      TData = integer;
      PElem =^TElem;
      TElem = record
          Data : TData;
          Next, Prev : PElem;
      end;

тогда так:
Код

procedure Add2End(D:TData; var P1,P2:PElem);
var NewElem:PElem;
Begin
      new(NewElem);
      NewElem^.Data:=D; 
      NewElem^.Next:=nil; 
      if P1=nil then begin
            NewElem^.Prev:=nil; 
            P1:=NewElem;
      end
      else begin
            NewElem^.Prev:=P2; 
            P2^.Next:=NewElem;
     end;
     P2:=NewElem;
End;


или я попутал очередь с двусвязным списком?
ну если очередь - односвязный список, то может так 

если
Код

Type
      TData = integer;
      PElem =^TElem;
      TElem = record
          Data : TData;
          Next : PElem;
      end;

тогда так:
Код

procedure Add2End(D:TData; var P1,P2:PElem);
var NewElem:PElem;
Begin
      new(NewElem);
      NewElem^.Data:=D; 
      NewElem^.Next:=nil; 
      if P1=nil then P1:=NewElem else P2^.Next:=NewElem;
      P2:=NewElem;
End;


Это сообщение отредактировал(а) v4v4n - 25.4.2011, 19:24
PM MAIL   Вверх
deimond
Дата 26.4.2011, 08:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 3.4.2011

Репутация: нет
Всего: нет



Спасибо большое, а что будет в теле основной программы?
PM MAIL   Вверх
deimond
Дата 5.5.2011, 20:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 3.4.2011

Репутация: нет
Всего: нет



Никак не разберусь с кодом основной программы.
Получилась такая ерунда, но не получается вывести очередь с добавленным элементом и вообще запутался с указателями P1 и P2. Как их задавать?
Сделал Add2End функцией, не разобрался как добавить результат выполнения процедуры в конце очереди.

Это сообщение отредактировал(а) deimond - 28.5.2011, 21:33
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0711 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.