0 / 0 / 0
Регистрация: 07.03.2015
Сообщений: 6

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

29.05.2015, 18:28. Показов 2774. Ответов 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
5096 / 2662 / 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
64319 / 47615 / 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru