Форум программистов, компьютерный форум, киберфорум
Turbo Pascal
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
3 / 3 / 0
Регистрация: 06.04.2011
Сообщений: 68

Разбиение списка на два списка одинаковой длины

02.10.2011, 15:21. Показов 2424. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста!!! НЕ оставьте в беде!!!!! Срочно нужна помощь!!!!!!!!!!!!!!!!!

Написать программу построения линейной списковой структуры, содержащей данные типа string, а также процедуру, реализующую разбиение списка на два списка одинаковой длины (+-1).

Заранее всем огромнейшее человеческое спасибо!!!!!
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.10.2011, 15:21
Ответы с готовыми решениями:

Тема: Списки. (разбиение списка на два списка одинаковой длины)
Сдрасти. Прошу помочь решить следующую задачу. Буду очень благодарен. Написать программу построения линейной списковой структуры,...

Объединить два списка одинаковой длины в третий так, чтобы вначале списка были элементы с нечётных позиций первог
Объединить два списка одинаковой длины в третий так, чтобы вначале списка были элементы с нечётных позиций первого списка, а в конце с...

Даны два списка одинаковой длины. Проверить, что каждый элемент первого списка больше соответствующего элемента второго
Даны два списка одинаковой длины. Проверить, что каждый элемент первого списка больше соответствующего элемента второго.

2
 Аватар для Mawrat
13114 / 5895 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
03.10.2011, 09:08
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Решение на односвязанном списке.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
program Project1;
 
type
  //Типы для описания списка.
 
  //Тип данных - определяет данные, которые будет содержать каждый элемент списка.
  TData = String;
  //Тип, описывающий элемент списка.
  TPElem = ^TElem;
  TElem = record
    Data : TData;
    PNext : TPElem;
  end;
  //Тип, описывающий список.
  TList = record
    PFirst : TPElem;
    PLast : TPElem;
  end;
 
//Процедуры для работы со списком.
 
//Удаление всего списка из памяти и инициализация.
procedure ListFree(var aList : TList);
var
  PNext, PDel : TPElem;
begin
  if aList.PFirst = nil then Exit;
 
  PNext := aList.PFirst;
  while PNext <> nil do begin
    PDel := PNext;
    PNext := PNext^.PNext;
    Dispose(PDel);
  end;
 
  aList.PFirst := nil;
  aList.PLast := nil;
end;
 
//Добавление элемента в конец списка.
procedure AddL(var aList : TList; const aPElem : TPElem);
begin
  if aPElem = nil then Exit;
 
  aPElem^.PNext := nil;
  if aList.PFirst = nil then begin
    aList.PFirst := aPElem;
    aList.PLast := aPElem;
  end else begin
    aList.PLast^.PNext := aPElem;
    aList.PLast := aPElem;
  end;
end;
 
var
  List1, List2, List3 : TList;
  PElem, PTmp : TPElem;
  i : Integer;
  S : String;
begin
  List1.PFirst := nil;
  List1.PLast := nil;
  List2.PFirst := nil;
  List2.PLast := nil;
  List3.PFirst := nil;
  List3.PLast := nil;
 
  repeat
    Writeln('Задайте первый список из строк.');
    Writeln('Ввод каждой строки завершайте нажатием клавиши Enter.');
    Writeln('Завершить ввод - пустая строка + Enter.');
    repeat
      Write('Строка: ');
      Readln(S);
      if S = '' then Continue;
      New(PElem);
      PElem^.Data := S;
      AddL(List1, PElem);
    until S = '';
 
    //Запись элементов в два других списка.
    PElem := List1.PFirst;
    i := 0;
    while PElem <> nil do begin
      Inc(i);
      PTmp := PElem;
      PElem := PElem^.PNext;
      if i mod 2 = 0 then
        AddL(List2, PTmp)
      else
        AddL(List3, PTmp)
      ;
    end;
    //Все элементы первого списка перенесены в другие списки.
    List1.PFirst := nil;
    List1.PLast := nil;
 
    //Распечатка составленных списков.
 
    Writeln('Второй список:');
    PElem := List2.PFirst;
    while PElem <> nil do begin
      Writeln(PElem^.Data);
      PElem := PElem^.PNext;
    end;
    Writeln;
    Writeln('Третий список:');
    PElem := List3.PFirst;
    while PElem <> nil do begin
      Writeln(PElem^.Data);
      PElem := PElem^.PNext;
    end;
    Writeln;
 
    //Удаление списокв из памяти.
    ListFree(List1);
    ListFree(List2);
    ListFree(List3);
    Writeln('Списки удалены из памяти.');
 
    Writeln('Повторить - Enter. Выход - любой символ + Enter.');
    Readln(S);
  until S <> '';
end.
0
3 / 3 / 0
Регистрация: 06.04.2011
Сообщений: 68
03.10.2011, 09:49  [ТС]
спасибо огромное
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.10.2011, 09:49
Помогаю со студенческими работами здесь

Даны два списка одинаковой длины, элементы которых - числа
Даны два списка одинаковой длины, элементы которых - числа. Выдать число 1, если произведение элементов первого списка больше произведения...

Разбить исходный список на два списка примерно одинаковой длины
Разбить исходный список на два списка примерно одинаковой длины. domains list = real* predicates nondeterm...

Разбиение списка на два примерно равной длины
задача простая но решить не могу :(( буду признателен. возможно скину небольшое поощрение на веб мани 1. Составить правило...

Даны два списка одинаковой длины, элементы которых - числа. Найти список с элементами - суммами соответствующих элементов исходных списков
Даны два списка одинаковой длины, элементы которых - числа. Найти список с элементами - суммами соответствующих элементов исходных списков.

Разбиение списка на два подсписка
Задание: Написать функцию, которая разбивает список на два подсписка: элементы из начала списка, совпадающие с первым элементом, и все...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru