0 / 0 / 0
Регистрация: 19.02.2018
Сообщений: 93

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

19.04.2018, 21:27. Показов 1766. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru