Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/13: Рейтинг темы: голосов - 13, средняя оценка - 4.92
0 / 0 / 0
Регистрация: 07.03.2015
Сообщений: 6

Уменьшить количество элементов массива

29.05.2015, 18:28. Показов 2764. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер.
Задание следующее:
Дано несколько массивов чисел. Длины массивов заданы в варианте индивидуального
задания. Требуется в каждом массиве найти наибольший и наименьший элементы и
отобразить их на экране, затем все компоненты каждого массива возвести в квадрат и снова
найти наибольший и наименьший элементы. Вычисление максимальной и минимальной
величин оформить в виде процедуры, глобальные параметры в процедуре не использовать.
(четыре массива, содержащие соответственно 4, 6, 3 и 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
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
function degree(osn:real;st:real):real;
var y:real;
begin
y:=exp(ln(abs(osn))*abs(st));
if st>0   then degree:=y
          else degree:=1/y;             
end;
 
const n=10; n1=4; n2=6; n3=3; n4=5;
type
      mas=array[1..n] of real;
var
      max,min,sqmax,sqmin:real;
      a1,a2,a3,a4:mas;
procedure search(var massiv:mas);
var 
      i:byte;
begin
      max:=massiv[1];
      min:=massiv[2];
      sqmax:=sqr(max);
      sqmin:=sqr(min);
      for i:=2 to n do begin
      if massiv[i]>max then max:=massiv[i];
      if sqr(massiv[i])>sqmax then sqmax:=sqr(massiv[i]);
      if massiv[i]<min then min:=massiv[i];
      if sqr(massiv[i])<sqmin then sqmin:=sqr(massiv[i]); end;
      writeln('Максимальный элемент в массиве: ',max,'    Минимальный:  ',min);
      writeln('Максимальный элемент в квадратном массиве: ',sqmax,'    Минимальный:  ',sqmin);
      
     
      
end;
 
var b,z,p:real;
    j:byte;
begin
    writeln('Массив №1:');
    for j:=1 to n1 do 
    a1[j]:=random(50);
    writeln(a1);
    search(a1);
    
    writeln('Массив №2:');
    for j:=1 to n2 do 
    a2[j]:=random(50);
    writeln(a2);
    search(a2);
    
    writeln('Массив №3:');
    for j:=1 to n3 do 
    a3[j]:=random(50);
    writeln(a3);
    search(a3);
    
    writeln('Массив №4:');
    for j:=1 to n4 do 
    a4[j]:=random(50);
    writeln(a4);
    search(a4);
    
    writeln('Введи число, которое нужно возвести в степень');
    readln(b);
    writeln('Введи степень,в которую нужно возвести число');
    readln(p);
    z:=degree(b,p);
    writeln('Значение выражения ',b,'^',p,'=',z);
end.
Так вот, все отлично, но минимальный элемент найти не удается вследствие того, что во всех массивах количество элементов - 10, и, соотвественно, в оставшихся ячейках просто стоят нули, которые и будут позже минимальными.

Подскажите, пожалуйста, как уменьшить количество элементов до того шага, где находится минимальный элемент?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.05.2015, 18:28
Ответы с готовыми решениями:

Уменьшить все элементы массива в 2 раза. Определить произведение элементов массива с k1 по k2
Дан целочисленный массив A. а)Уменьшить все элемент массива в 2 раза. б)Определите произведение элементов массива с k1 по k2

Уменьшить размер файла до 50 элементов, удалив из него необходимое количество конечных элементов
Дан(создать) файл целых чисел, содержащий более 50 элементов. Уменьшить его размер до 50 элементов, удалив из файла необходимое количество...

Уменьшить размер файла до 50 элементов, удалив из файла необходимое количество началь-ных элементов
Дан файл целых чисел, содержащий более 50 элементов. Уменьшить его размер до 50 элементов, удалив из файла необходимое количество...

3
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
01.06.2015, 06:25
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
procedure search(n : byte; var massiv:mas);
var 
      i:byte;
begin
      max:=massiv[1];
      min:=massiv[2];
      sqmax:=sqr(max);
      sqmin:=sqr(min);
      for i:=2 to n do begin
      if massiv[i]>max then max:=massiv[i];
      if sqr(massiv[i])>sqmax then sqmax:=sqr(massiv[i]);
      if massiv[i]<min then min:=massiv[i];
      if sqr(massiv[i])<sqmin then sqmin:=sqr(massiv[i]); end;
      writeln('Максимальный элемент в массиве: ',max,'    Минимальный:  ',min);
      writeln('Максимальный элемент в квадратном массиве: ',sqmax,'    Минимальный:  ',sqmin);
end;
… и значит вызываем вот так:
Pascal
1
2
3
4
5
…
search(n1, a1);
…
search(n2, a2);
1
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
01.06.2015, 06:53
Точно на такой же вопрос отвечал, буква в букву, но автор другой был. Клонируешься что ли?
0
0 / 0 / 0
Регистрация: 07.03.2015
Сообщений: 6
02.06.2015, 14:24  [ТС]
JuriiMW, спасибо, но уже исправил.

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
type a=array[1..10] of integer;
var 
max,min,sqmax,sqmin:integer;
 
procedure get(var mas:a; n:byte);
var
  i:byte;
begin
  for i:=1 to n do begin
  mas[i]:=random(50);
  write(mas[i],' '); end;
  writeln;
end;
procedure poisk(mas:a; n:byte);
var i:byte;
begin
      max:=mas[1];
      min:=mas[2];
      sqmax:=sqr(max);
      sqmin:=sqr(min);
      for i:=1 to n do begin
      if mas[i]>max then max:=mas[i];
      if sqr(mas[i])>sqmax then sqmax:=sqr(mas[i]);
      if mas[i]<min then min:=mas[i];
      if sqr(mas[i])<sqmin then sqmin:=sqr(mas[i]); end;
      writeln('Максимальный элемент в массиве: ',max,'    Минимальный:  ',min);
      writeln('Максимальный элемент в квадратном массиве: ',sqmax,'    Минимальный:  ',sqmin); end;
 
var i,j:byte; c,h:a;
begin
  get(c,4); poisk(c,4); get(c,6); poisk(c,6); get(c,3);poisk(c,3); get(c,5); poisk(c,5);
end.
Puporev, нет.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.06.2015, 14:24
Помогаю со студенческими работами здесь

Вычислить количество элементов массива, равных заданному числу, и произведение элементов массива с чётными номерами
а). Вычислить количество элементов массива А(20) равных заданному числу Х. б). Вычислить произведение элементов массива А(20), с чётными...

Найти количество элементов массива Х, совпадающих со значениями элементов массива Y
Для получения результата составить функцию, исходными данными которой являются два массива x1,x2,...,xn u y1,y2.(один из них) или матрица А...

Определить количество положительных и количество отрицательных элементов массива
определить количество положительных и количество отрицательных элементов массива

Определить количество положительных и количество отрицательных элементов массива
Определить количество положительных и количество отрицательных эле- ментов массива.

Вывести количество элементов массива которые большего среднего значения массива
1) Вообщем задача звучит так: Дан целочисленный массив из 30 элементов.Элементы массива могут принимать целые значения от 0 до 100 -...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
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