IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Задача с массивом
RAPON
сообщение 13.04.2009 19:58
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 47
Пол: Мужской

Репутация: -  0  +


Помогите решить.
В массиве целых чисел с количеством элементов n найти наиболее часто встречающееся число. Если таких чисел несколько, то определить наименьшее из них.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
amega
сообщение 13.04.2009 20:29
Сообщение #2


?
***

Группа: Пользователи
Сообщений: 283
Пол: Мужской

Репутация: -  4  +


не ну вы ребята издеватесь!!!
которая по счету тема задача с масивами!!!!!!!!!!!!!!!!!!!

может не совсем функционально но вот пример реализаци с помощю списка



Type
TPrec=^Trec;
Trec = record
inf :integer;
count :integer;
next :TPrec;
end;
const n=100;
Var
arr=array [1..n] of integer;
i:integer;
start:tprec;
wp:tprec;


function findrec(elem:integer;var wp:tprec):boolean;
begin
result:=false;
wp:=start;
while wp<>nil do
begin
if wp^.inf=elem then
begin
result:=true;
exit;
end;
wp:=wp^.next;
end;
end;

procedure add(elem:integer; var start:tprec);
var
Pnew:Tprec;
begin
new(pnew);
pnew^.inf:=elem;
pnew^.count:=1;
pnew^.next:=nil;
if start=nil then
begin
start:=pnew;
end
else
begin
pnew^.next:=start;
start:=pnew;
end;
end;

begin
start:=nil;
{заполнение масива}
for i:=1 to n do begin
if findrec(arr(i),wp) then inc(wp^.count)
else add(arr(i),start);

{теперь проходиш по списку и виводиш то что нужно}

while start<>nil do
begin
wp:=start;
start:=start^.next;
dispose(wp);
end;
end;



зы еще не откомпилирова, откомпилирую исправлю если будут ошибки)

Сообщение отредактировано: amega - 13.04.2009 20:32
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 21.06.2025 23:15
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"