Форум программистов, компьютерный форум, киберфорум
Free Pascal
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
0 / 0 / 1
Регистрация: 02.12.2012
Сообщений: 6

Подсчитать количество элементов массива, больших среднего арифметического значения всех его элементов

11.12.2012, 04:46. Показов 1231. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите, пожалуйста, исправить программу.
Нужно подсчитать количество элементов массива, больших среднего арифметического значения всех его элементов.
Само задание:
Дан текстовый файл размером не более 64 Кб, содержащий действительные числа, по одному в каждой строке. Переписать содержимое файла в массив, разместив его в динамически распределяемой памяти. Вычислить среднее значение элементов массива. Очистить динамическую память. Создать целый массив размером 10000, заполнить его случайными целыми числами в диапазоне от –100 до 100 и вычислить его среднее значение.
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
Program Srednee;
  Const NMax = 10000;
  Type Diapazon = 1..NMax;
       MasInt = Array[Diapazon] Of Integer;
       MasReal = Array[Diapazon] Of Real;
  Var PInt : ^MasInt; PReal : ^MasReal;
      I, Midint : longInt; MidReal : Real; 
      T : Text; S : string;
Begin
  Write('Введите имя файла: '); ReadLn(S);
  Assign(T, S); Reset(T); 
  MidReal:=0; MidInt:=0; {Подготовка к суммированию}
  Randomize;
  NEW(PReal); {Выделение памяти под вещественный массив}
  {Ввод и суммирование вещественного массива}
  I:=0;
  While Not Eof (T) Do
  Begin Inc(I);
        ReadLn(T, PReal^[I]); 
        MidReal := MidReal + PReal^[I];
  End;
  DISPOSE(PReal); {Удаление вещественного массива}
  NEW(PInt); {Выделение памяти под целый массив}
  {Вычисление и суммирование целого массива}
  For I := 1 To NMax Do
  Begin PInt^[I] := -100 + Random(201);
        Write (Pint^[I]:4); 
        MidInt := MidInt + PInt^[I] 
  End;
  Writeln;
 {Вывод средних значений:}
  WriteLn('среднее целое равно: ', MidInt Div NMax);
  WriteLn('среднее вещественное равно: ', (MidReal/NMax):10:4)
  Close(T)
End.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.12.2012, 04:46
Ответы с готовыми решениями:

Для динамического массива подсчитать количество его элементов, больших среднего арифметического значения
Для динамического массива подсчитать количество его элементов, больших среднего арифметического значения всех его элементов.

Подсчитать количество элементов, больших среднего арифметического значения всех положительных элементов
Для динамического массива подсчитать количество его элементов, больших среднего арифметического значения всех его положительных элементов

Определить количество элементов, больших среднего арифметического всех элементов
определить количество элементов больших среднего арифметического всех элементов const maxN = 100; type massiv = array ...

2
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33399 / 21509 / 8236
Регистрация: 22.10.2011
Сообщений: 36,907
Записей в блоге: 12
11.12.2012, 14:09
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
Program Srednee;
  Const NMax = 10000;
  Type Diapazon = 1..NMax;
       MasInt = Array[Diapazon] Of Integer;
       MasReal = Array[Diapazon] Of Real;
  Var PInt : ^MasInt; PReal : ^MasReal;
      I, CountReal, Midint : longInt; MidReal : Real; 
      T : Text; S : string;
Begin
  Write('Введите имя файла: '); ReadLn(S);
  Assign(T, S); Reset(T); 
  MidReal:=0; MidInt:=0; {Подготовка к суммированию}
  Randomize;
  NEW(PReal); {Выделение памяти под вещественный массив}
  {Ввод и суммирование вещественного массива}
  I:=0;
  While Not Eof (T) Do
  Begin Inc(I);
        ReadLn(T, PReal^[I]); 
        MidReal := MidReal + PReal^[I];
  End;
 
  CountReal := i; { Запоминаем число элементов, прочитанных из файла }
 
  DISPOSE(PReal); {Удаление вещественного массива}
  NEW(PInt); {Выделение памяти под целый массив}
  {Вычисление и суммирование целого массива}
  For I := 1 To NMax Do
  Begin PInt^[I] := -100 + Random(201);
        Write (Pint^[I]:4); 
        MidInt := MidInt + PInt^[I] 
  End;
  Dispose(PInt); { <--- Не забываем удалить }
  Writeln;
 {Вывод средних значений:}
  WriteLn('среднее целых равно: ', (MidInt/CountReal):10:4); { Среднее - это вещественное число }
  WriteLn('среднее вещественных равно: ', (MidReal/CountReal):10:4); { <--- Делить надо не на NMax, а на CountReal }
  Close(T)
End.
P.S. Можно еще проверить CountReal на 0 перед делением на него (если файл может быть пустым).
1
0 / 0 / 1
Регистрация: 02.12.2012
Сообщений: 6
26.12.2012, 00:12  [ТС]
Спасибо огромное!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
26.12.2012, 00:12
Помогаю со студенческими работами здесь

Найти количество элементов, больших среднего арифметического всех элементов столбца матрицы. Блок схема
program Project1;(*Дана матрица размера m x n. В каждом ее столбце найти количество элементов, больших среднего арифметического...

В каждом столбце матрицы найти количество элементов, больших среднего арифметического всех элементов этого столбца
Данная матрица размера М × N. В каждом ее столбце найти количество элементов, больших среднего арифметического всех элементов этого...

Подсчитать количество элементов файла f, меньших среднего арифметического всех элементов
Пусть type reals = file of real; Подсчитать количество элементов файла f, меньших среднего арифметического всех элементов этого файла....

Определить количество элементов массива, больших среднего арифметического
Задание следующее: В данном числовом массиве определить количество элементов массива, больших среднего арифметического.

Вычислить сумму и количество элементов массива, больших среднего арифметического
Вычислить сумму и количество элементов массива X больших числа a, где a – среднее арифметическое элементов массива X. Элементы массива...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
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
прикрепляю статью
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru