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

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

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

> Циклический сдвиг, на динамических данных
Гость
сообщение 21.02.2007 23:04
Сообщение #1


Гость






Помогите плиз!
Нужно с помощью динамичесой организации данных, организовать сдвиг впрво. Пример вводим L1=(a, b, c) , а выводим L2=(c, a, b).

Кто поможет в двух-трёх словах как лучше организовать цикличкский сдвиг на одни элемент вправо?

сразу большое спасибо

М
Гость, не задавай вопросы в чужих темах! Предупреждение..
Тема разделена. Lapp


 ! 
Как оказалось позднее, ты сделал это ДВА раза!
Второе ПРЕДУПРЕЖДЕНИЕ!
Твоя подсеть может вся пострадать за тебя..
Lapp

 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
xds
сообщение 23.02.2007 6:15
Сообщение #2


N337
****

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

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


Цитата
Вообщето задание на С
Здесь будет только на Паскале. Иначе - в разделе "Другие языки".

Вот возможная реализация. Используется двунаправленный список с фиктивным элементом. Такая организация списка позволяет без дополнительного просмотра списка: добавлять элементы в начало и конец списка, удалить любой элемент, вставить элемент в произвольное место списка, выводить список в любом порядке, сдвигать список с обоих направлениях. Использование фиктивного элемента избавляет нас от проверок на пустоту списка и его границы. Разберись - пригодится!

program ShiftList;

type
PList = ^TList;
TList = record
Prev, Next: PList;
n: Integer;
end;

procedure InitList(var List: TList);
begin
List.Prev := @List;
List.Next := @List;
end;

procedure AddItem(var List: TList; n: Integer);
var
p: PList;
begin
New(p);
p^.Next := @List;
p^.Prev := List.Prev;
List.Prev^.Next := p;
List.Prev := p;
p^.n := n;
end;

procedure FreeList(var List: TList);
var
p: PList;
begin
while List.Next <> @List do
begin
p := List.Next;
List.Next := p^.Next;
Dispose(p);
end;
List.Prev := @List;
end;

procedure ShrList(var List: TList);
var
p: PList;
begin
p := List.Prev;

List.Prev := p^.Prev;
List.Prev^.Next := @List;

p^.Next := List.Next;
p^.Next^.Prev := p;
p^.Prev := @List;
p^.Prev^.Next := p;
end;

procedure WriteList(const List: TList);
var
p: PList;
begin
p := List.Next;
while p <> @List do
begin
Write(p^.n, ' ');
p := p^.Next;
end;
Writeln;
end;

var
List: TList;
i: Integer;

begin
InitList(List);

for i := 1 to 10 do
AddItem(List, i);

WriteList(List);

ShrList(List);
WriteList(List);

ShrList(List);
WriteList(List);

ShrList(List);
WriteList(List);

FreeList(List);

Writeln;
end.


--------------------
The idiots are winning.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


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

 



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