![](/logo_grey.gif)
Последние записи
- Проверка на шестнадцатеричный формат записи
- Отдать пользователю файл с помощью file_get_contents()
- Написать собственую функцию operator[] для битов
- Проблема с движением 2D человека
- OpenGl.Создание винтовой лестницы
- Склеить несколько файлов в один
- Windows 10 сменить администратора
- Рандомное слайдшоу
- Событие для произвольной области внутри TImage
- Удаление папки с файлами
![](http://programmersclub.ru/slurm3.jpg)
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
![](http://programmersclub.ru/katajpg.jpg)
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
21st
Дек
Поиск повторяющихся элементов в массиве
Posted by obzor under Delphi
В произвольном массиве из n целых чисел (n<100) найти повторяющиеся элементы и количество повторений каждого из таких элементов.
Исходные данные
Первая строка содержит количество элементов массива n.
Затем следуют элементы массива (целые числа), каждый в отдельной строке.
Результат
Первая строка должна содержать количество повторяющихся элементов в массиве, если повторяющихся элементов нет, то вывести ноль.
Затем идут повторяющиеся элементы массива, если они есть, в каждой строке через пробел сначала сам элемент, а затем количество его повторений (элементы расположены в порядке расположения в массиве первого из повторяющихся элементов).
type mas = array [1..100] of byte;
var a, ac, ack : mas;
N,NC : byte;
procedure readdata;
var i,j,k:byte;b:boolean;
f,fout:text;
begin
assign(f,'inp.txt');reset(f);
assign(fout,'inp.out');rewrite(fout);
readln(f,n);
b:=false;
NC:=0;
for i:=1 to n do
begin
readln(f,a[ i]);
for j:=1 to i-1 do
if a[ i]=a[j] then {est dublikat}
begin
for k:=1 to NC do {smotrim w spiske dublikatov}
begin
if ac[k]=a[j] then {w spiske dublikatov est}
begin
inc(ack[k]);
b:=true;
break
end
end;
if not(b) then {s spiske dublej nety}
begin
inc(nc);
ac[nc]:=a[ i];
ack[nc]:=2;
end
else break
end;
end;
writeln(fout,NC);
for i:=1 to Nc do
writeln(fout,ac[ i],' ',ack[ i]);
close(f); close(fout);
end;
BEGIN
readdata;
end.
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
![пеллетные котлы](http://programmersclub.ru/respective.jpg)
пеллетные котлы
![пеллетный котел](http://programmersclub.ru/emtas.jpg)
Пеллетный котел Emtas
![форум программистов](http://programmersclub.ru/banf336х280.gif)
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)