С Новым годом! Форум программистов, компьютерный форум, киберфорум
Delphi для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 19.02.2018
Сообщений: 93

Описать и проверить процедуру или функцию, которая проверяет, есть ли в списке L хотя бы два одинаковых элемента

19.04.2018, 21:27. Показов 1731. Ответов 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
unit Unit1;
 
interface
 
uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls;
 
type
list=^zveno;
  zveno= record
           elem:string;
           sled:list;
         end;
  TForm1 = class(TForm)
    Memo1: TMemo;
    Button1: TButton;
    Edit1: TEdit;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
 
var
  Form1: TForm1;
 
implementation
 
{$R *.dfm}
 
procedure TForm1.Button1Click(Sender: TObject);
var x,y: list;
      i: integer;
      k:boolean;
function foo (y1:list):boolean;
var   p1,p2:string; q,next:List;
 begin
     foo:=False;
     q:=y1^.sled;
     p1:=y1^.elem;
     p2:=q^.elem;
     while q<>Nil do
   begin
     if p1 = p2 then
       begin
         foo:=True;
         break;
       end else
     y1:=q;
     q:=q^.sled;
     p1:=y1^.elem;
     p2:=q^.elem;
  end;
  end;
begin
  y:=nil;
 for i:=1 to Memo1.Lines.Count do begin
   new(x);
   x^.elem:=Memo1.Lines[i-1];
   x^.sled:=y;
   y:=x;
 end;
 k:=foo(y);
 if (k) then
   Edit1.Text:='Есть'
 else
   Edit1.Text:='Нет';
end;
 
end.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.04.2018, 21:27
Ответы с готовыми решениями:

Написать функцию Double, которая проверяет, есть ли в дереве хотя бы два одинаковых элемента
Есть описание дерева type BT=longint; U=^BinTree; BIntree=record inf:BT; l,r:u; ...

Опишите подпрограмму, которая проверяет если ли в списке хотя бы два одинаковых элемента.
Опишите подпрограмму, которая проверяет если ли в списке хотя бы два одинаковых элемента. проблема в следующем когда список состоит из ...

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

2
1 / 0 / 1
Регистрация: 09.11.2018
Сообщений: 5
15.04.2019, 15:55
Delphi
1
2
3
4
y1:=q;
q:=q^.l;
p1:=y1^.a;
p2:=y1^.a;
0
1 / 0 / 1
Регистрация: 09.11.2018
Сообщений: 5
29.04.2019, 20:50
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
unit Unit3;
 
interface
 
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;
 
type
  data=string;
  link=^item;
  item=record
    a:data;
    l:link
  end;
  TForm1 = class(TForm)
    Memo1: TMemo;
    Button1: TButton;
    Label1: TLabel;
    Edit1: TEdit;
    Label2: TLabel;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
 
var
  Form1: TForm1;
 
implementation
 
{$R *.dfm}
 
procedure TForm1.Button1Click(Sender: TObject);
var x,y: link;
      i: integer;
      k:boolean;
function foo (y1:link):boolean;
var q:link;
 begin
     foo:=False;
     while y1^.l <> nil do begin
     q:=y1^.l;
     while q <> nil do
      if y1^.a = q^.a then begin
      foo:=true;
      break;
      end
      else q:=q^.l;
      y1:=y1^.l
     end;
 end;
begin
  y:=nil;
 for i:=1 to Memo1.Lines.Count do begin
   new(x);
   x^.a:=Memo1.Lines[i-1];
   x^.l:=y;
   y:=x;
 end;
 k:=foo(y);
 if (k) then
   Edit1.Text:='Есть'
 else
   Edit1.Text:='Нет';
end;
 
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.04.2019, 20:50
Помогаю со студенческими работами здесь

Проверить, есть ли в списке хотя бы два одинаковых элемента
Прошу проверить правильность кода и помочь написать его дальше. Написать программу, обеспечивающую работу с динамическими структурами -...

Проверить, есть ли в списке L хотя бы два одинаковых элемента
1)Составить программу, которая проверяет, есть ли в списке L хотя бы два одинаковых элемента. 2) Составить программу, которая переносит в...

Проверить, есть ли в списке хотя бы два одинаковых элемента
Дан список А, состоящий из записей: первое поле – символ, второе – адрес следующего элемента. Составить программу, которая проверяет, есть...

Проверить, есть ли в списке хотя бы два одинаковых элемента
Написать логическую функцию, которая проверяет, есть ли в списке хотя бы два одинаковых элемента. Если условие выполняется, добавить новый...

Проверить, есть ли в списке хотя бы два одинаковых элемента
1. Проверить, есть ли в списке хотя бы два одинаковых элемента Помогите, пожалуйста, разобраться в чём проблема. Это же консольная...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru