Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 13.04.2013
Сообщений: 34

Если элемент массива не уникальный то удалить его [11233 -> 2]

26.11.2013, 20:43. Показов 888. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет. Собственно, вопрос в теме.
Вот одна из моих неудачных попыток.
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
var i, tmp, ii, k, n, j:integer;
A:array[1..10] of integer;
begin
  write('n = ');
  read(n);
  for i:=1 to n do
  begin
    write('A[', i, '] = ');
    read(A[i]);
  end;
  
  for i:=1 to n do
  begin
    for j:=i+1 to n do
    begin
      if A[i]=A[j] then
      begin
        tmp:=A[i];
        ii:=i;
        writeln;
        //write(tmp, '   ', ii);
      end;
    end;
    for j:=1 to n do
    begin
      if A[j]=tmp then
      begin
        for k:=j to n-1 do
        begin
          A[k]:=A[k+1];
          dec(n);
        end;
      end;
    end;
  end;
  for i:=1 to n do
  write(A[i]);
end.
Я могу удалить повторяющийся элемент.
Могу сделать вышенаписанное задание, но только для чётных повторений. [11233]->[2], но [112333] - не работает.

Если можно, объясните, пожалуйста, почему мой код не работает и преведите рабочий.

Заранее благодарен.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.11.2013, 20:43
Ответы с готовыми решениями:

Если элемент найден, то удалить его и следующий за ним элемент из массива
Сформировать массив x, упорядоченный по убыванию. Определить, содержит ли он заданное число. Если элемент найден, то удалить его и...

Заменить элемент массива на сумму его соседей, если элемент массива четный и номер его лежит в промежутке от a до b
Случайным образом генерируется массив чисел. Пользователь вводит числа a и b. Заменить элемент массива на сумму его соседей, если элемент...

Заменить элемент массива на сумму его соседей, если элемент массива четный и номер его лежит в промежутке
Случайным образом генерируется массив чисел. Пользователь вводит числа a и b. Заменить элемент массива на сумму его соседей, если элемент...

5
0 / 0 / 0
Регистрация: 13.04.2013
Сообщений: 34
27.11.2013, 21:44  [ТС]
Ещё получилось сделать это задания, но работает только тогда, когда элементы стоят рядом.

Добавлено через 22 секунды
Need help please!
0
 Аватар для Jener
228 / 225 / 220
Регистрация: 03.07.2012
Сообщений: 466
28.11.2013, 06:23
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
uses
  crt;
const
  Nmax = 10;  
type
  TMass = array[1..Nmax] of integer;  
procedure InitMass(var a : TMass; N : byte);
var i : byte;
begin
  for i := 1 to N do begin
    write('a[',i,'] = ');readln(a[i]);
  end;  
end;  
procedure PrintMass(a : TMass; N : byte);
var i : byte;
begin
  for i := 1 to N do write(a[i]:4);
  writeln;
end;
var 
  a : TMass;
  N, i, j, k : byte;
  bol, bol1 : boolean;
begin
  clrscr;
  repeat
  write('N = '); readln(N);
  until N<=Nmax;
  InitMass(a,N);
  PrintMass(a,N);
  i := 1;  
  while i<=N-1 do begin
    bol := true;
    j := i + 1;
    while j<=N do begin
      bol1 := true; 
      if a[i]=a[j] then begin 
        bol1 := false; 
        bol := false;       
        k := j;  
      end;
      if bol1 then inc(j)
      else begin
        while k<=N-1 do begin
          a[k] := a[k+1];
          inc(k);
        end;  
        dec(N);
      end;
    end;
    if bol then inc(i)
    else begin
      j := i;   
      while j<=N-1 do begin 
        a[j] := a[j+1];
        inc(j); 
      end;
      dec(N);
    end;      
  end;
  PrintMass(a,N);
  readln;
end.
1
0 / 0 / 0
Регистрация: 13.04.2013
Сообщений: 34
30.11.2013, 19:55  [ТС]
Торович, спасибо большое. Всё работает. Но у меня есть несколько вопросов, ибо я не понимаю, как она работает.

Code
1
2
3
4
5
Допустим, у нас есть массив: 11184554.
Первый элемент равен второму, значит bol и bol1 становятся ложными. 
Происходит удаление, остаётся 184554.
Далее мы опять заходим в цикл while i<=n-1 do, i=1, так как при удалении нет инкримента i. 
И тут уже видно, что элемента равного 1 больше нам не найти => он не удалится.
Это моя логика.

А как же работает программа, объясните, пожалуйста.
0
 Аватар для Jener
228 / 225 / 220
Регистрация: 03.07.2012
Сообщений: 466
01.12.2013, 06:01
Проходим массив поэлементно - если элемент
уникален т. е. нет равных в массиве, то переходим к следующему иначе
удаляем все повторные вхождения элемента - bol1 показывает, и удаляем сам этот элемент
bol - показывает.
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
  i := 1;  
  while i<=N-1 do begin //проходим массив поэлементно до предпоследнего  
    bol := true;         //элемент уникален
    
    j := i + 1;
    while j<=N do begin  
      bol1 := true;   
      if a[i]=a[j] then begin  //сравниваем элемент с остальными элементами массива 
        bol1 := false; 
        bol := false;       
        k := j;  
      end;
      //если есть повторные вхождения - удаляем эти элементы
      if bol1 then inc(j)
      else begin
        while k<=N-1 do begin
          a[k] := a[k+1];
          inc(k);
        end;  
        dec(N);
      end;
    end;
        
    if bol then inc(i) //элемент уникален - переходим к следующ
    else begin       //удаляем этот элемент     
    j := i;   
      while j<=N-1 do begin 
        a[j] := a[j+1];
        inc(j); 
      end;
      dec(N);
    end;      
    PrintMass(a,N);  //процедура для наглядности
  end;
0
0 / 0 / 0
Регистрация: 19.03.2014
Сообщений: 2
19.03.2014, 16:22
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
const
    n = 20;
 
var
    a: array[1..n] of integer; //сжимаемый массив
    s: array[1..n] of integer; //сжатый массив
    i,k,l: integer;
    flag: boolean;
 
begin
    randomize;
 
    for i := 1 to n do begin
        a[i] := random(10);
        write (a[i]:3)
    end;
    writeln;
 
    for i := 1 to n do
        s[i]:=-1;
 
    k := 1;
    for i := 1 to n do begin
        flag := true;
        for l := 1 to k do
            if s[l] = a[i] then
                flag := false;
        if flag = true then begin
            s[k] := a[i];
            k := k+1
        end;
    end;
 
    for i := 1 to k-1 do
        write (s[i]:3);
 
readln
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.03.2014, 16:22
Помогаю со студенческими работами здесь

Методом бинарного поиска определить, содержит ли массив заданное число. Если элемент найден, то удалить его из массива
Сформировать массив А, упорядоченный по возрастанию. Методом бинарного поиска определить, содержит ли он заданное число. Если элемент...

Если элемент найден, то удалить его и стоящий перед ним элемент
всем привет, подскажите как сделать чтобы, чтобы удалялся перед найденым, стоящий перед ним элемент. {Сформировать массив Х,...

Если элемент массива положительный то возвести его в квадрат если отрицательный то прибавить 20.
если элемент массива положительный то возвести его в квадрат если отрицательный то прибавить 20. Без рандома а с клавиатуры

Удалить первый отрицательный элемент массива, если такой элемент есть
1. Удалить первый отрицательный элемент массива, если такой элемент есть. 2. Вставить два элемента с данными значениями: первый – после...

Если элемент массива меньше 1000 - то поменять его на ноль, если больше - заменить на 1
Массив из 10 чисел, если число меньше 1000 то поменять на ноль если больше то заменить на 1 , и вывести на экран. Благодарю заранее!


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
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
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru