1 / 1 / 2
Регистрация: 07.11.2013
Сообщений: 30

двусвязный список

10.02.2014, 20:17. Показов 1427. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
помогите дописать программу.
Delphi
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
125
126
127
128
129
130
131
132
{Ввести последовательность натуральных чисел. Если в последовательности есть простые числа,
 упорядочить последовательность по неубыванию суммы цифр. В противном случае удалить из
 последовательности числа с нечетным количеством цифр и продублировать 4-х значные числа.
 Последовательность хранить в двусвязном циклическом списке с фиктивным элементом.}
 
program labor18;
 
{$APPTYPE CONSOLE}
 
uses
  SysUtils;
 
type pList=^TList;
     TList=record
            Data:integer;
            L,R:pList;
            end;
var
    num,l,z,h,u,n:integer;
    sent,p,q,tmp:pList;
function Add(data:integer;pred:pList):pList;
 
begin
  New(P);
  p^.data:=data;
  p^.l:=pred;
  p^.r:=pred.R;
  pred^.r:=p;
  result:=P;
end;
 
function prime(x:Integer):Boolean;
var d :Integer;
begin
  prime:=False;
  if x<2 then Exit;
    for d:=2 to Round(Sqrt(x)) do
      if x mod d=0 then
        Exit;
 
  prime:=True;
end;
 
function kol(var a:Integer):Boolean;
begin
  kol:=False;
  n:=a;
  u:=0;
  while n>0 do begin
    inc(u);
    n:=n div 10;
  end;
  if (u mod 2<>0) then kol:=True;
end;
 
function kol2(var a:Integer):Boolean;
begin
  kol2:=False;
  n:=a;
  u:=0;
  while n>0 do begin
    inc(u);
    n:=n div 10;
  end;
  if u=4 then kol2:=True;
end;
 
function sum(a:Integer):Integer;
var
  s:Integer;
begin
  n:=a;
  s:=0;
  while n>0 do begin
    s:=n mod 10+s;
    n:=n div 10;
  end;
  Result:=s;
end;
 
begin
  Reset(Input,'input.txt');
  Rewrite(Output,'output.txt');
  New(sent);
  sent^.l:=sent;
  sent^.r:=sent;
  p:=sent^.R;
  while not SeekEoln do begin
    read(num);
    p:=add(num,p);
  end;
  l:=0;
  p:=sent^.R;
  while p<>sent do begin
    if prime(p^.Data) then inc(l);
    p:=p^.R;
  end;
  if l<>0 then begin
    p:=sent^.R;
    while p<>sent do begin
      z:=sum(p^.Data);
      h:=sum(p^.r^.Data);
      if z>h then begin
        {здесь нужно поменять местами p^.Data и p^.r^.Data}
      end;
      p:=p^.R;
    end;
  end else begin
    p:=sent^.r;
    while p<>sent do begin
      if kol(p^.Data) then begin
        p^.l^.R:=p^.R;
        p^.r^.l:=p^.L;
      end else
        if kol2(p^.Data) then begin
          q:=p;
          New(tmp);
          tmp^.Data:=q^.Data;
          tmp^.l:=q;
          tmp^.r:=q^.R;
          q^.r^.l:=tmp;
          q^.r:=tmp;
          p:=p^.R;
        end;
      p:=p^.R;
    end;
  end;
  p:=sent^.R;
  while p<>sent do begin
    write(p^.data,' ');
    p:=p^.R;
  end;
как видно на 104 строчке мне надо упорядочить последовательность по неубыванию суммы цифр. суммы цифр я нашёл
осталось только поменять местами два элемента как сделать????
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.02.2014, 20:17
Ответы с готовыми решениями:

Односвязный и двусвязный список
Составить программу, которая из списка из n элементов удаляет в порядке просмотра каждый k-1-й элемент. Распечатать номера удаленных...

Двусвязный список. Добавление
У меня стоит задача создать двусвязный список и различные процедуры к нему. За основу я взял вот этот ...

Двусвязный список, сортировка пузырьком
Доброго времени суток уважаемые форумчане. Нужна помощь написания программы. Условие такое: написать двусвязный список и провести в нём...

2
 Аватар для Mawrat
13116 / 5897 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
11.02.2014, 12:58
Цитата Сообщение от enurgoo Посмотреть сообщение
поменять местами два элемента как сделать????
Delphi
1
2
3
var
  Data : Integer;
...
Delphi
103
104
105
106
107
108
      if z>h then
      begin
        Data := p^.Data;
        p^.Data := p^.r^.Data;
        p^.r^.Data := Data;
      end;
0
1 / 1 / 2
Регистрация: 07.11.2013
Сообщений: 30
14.02.2014, 22:04  [ТС]
Цитата Сообщение от enurgoo Посмотреть сообщение
p:=sent^.R;
* * while p<>sent do begin
* * * z:=sum(p^.Data);
* * * h:=sum(p^.r^.Data);
* * * if z>h then begin
* * * * {здесь нужно поменять местами p^.Data и p^.r^.Data}
* * * end;
* * * p:=p^.R;
* * end;
надо было так после if l<>0 then begin
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
    p:=sent^.r;
    w:=p^.r;
    while  w<>sent do begin
      j:=w^.l;
      z:=sum(j^.Data);
      h:=sum(w^.Data);
      while (j<>sent) and (z>h) do begin
        num:=j^.Data;
        j^.Data:=w^.Data;
        w^.Data:=num;
        j:=j^.L;
        w:=w^.L;
        z:=sum(j^.Data);
        h:=sum(w^.Data);
      end;
      w:=w^.R;
    end;
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.02.2014, 22:04
Помогаю со студенческими работами здесь

Стек, очередь и двусвязный список
Решить для случая реализации списка в виде стека, очереди и двусвязного списка: Разработать процедуры и функции, предварительно выбрав...

Двусвязный список в виде класса. delphi
Здравствуйте. Проверьте, пожалуйста, правильно ли выполнено задание: Реализуйте заданную структуру данных (двусвязный список целых...

Двусвязный список. Метод, возвращающий указатель
Делаю класс двусвязного списка TBarNode = record BarData: TBar; Next: ^TBarNode; Prev: ^TBarNode; PSARIndex:...

Создать двусвязный линейный список, упорядоченный в порядке обратном алфавитному...
Добрый день. Нужно создать двусвязный линейный список, упорядоченный в порядке обратном алфавитному и из N псевдослучайных, из массива...

Преобразовать двусвязный список: оставить только первые вхождения элементов с одинаковой инф. частью
Задание звучит так: Преобразовать двусвязный список так, чтобы в нем остались только первые вхождения элементов с одинаковой...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru