В одномерном массиве, состоящем из n вещественных элементов, вычислить: - Free Pascal

Узнай цену своей работы

Формулировка задачи:

1. В одномерном массиве, состоящем из n вещественных элемен- тов, вычислить: 1) сумму отрицательных элементов массива; 2) произведение элементов массива, расположенных между мак- симальным и минимальным элементами. Упорядочить элементы массива по возрастанию. Ну это уже не для моего мозга))

Решение задачи: «В одномерном массиве, состоящем из n вещественных элементов, вычислить:»

textual
Листинг программы
  1. uses crt;
  2. const nmax=100;
  3. var a:array[1..nmax] of real;
  4.     n,i,j,k,imn,imx:byte;
  5.     s,p,x:real;
  6. begin
  7. textbackground(0);
  8. textcolor(15);
  9. clrscr;
  10. randomize;
  11. repeat
  12. write('Размер массива n=');
  13. readln(n);
  14. until n in [1..nmax];
  15. writeln('Исходный массив:');
  16. s:=0;
  17. for i:=1 to n do
  18.  begin
  19.   a[i]:=-10+30*random;
  20.   write(a[i]:5:1);
  21.   if a[i]<0 then s:=s+a[i];
  22.  end;
  23. writeln;
  24. writeln('Сумма отрицательных=',s:0:1);
  25. imn:=1;
  26. imx:=1;
  27. for i:=1 to n do
  28.  begin
  29.   if a[i]<a[imn] then imn:=i;
  30.   if a[i]>a[imx] then imx:=i;
  31.  end;
  32. writeln('Номер минимального=',imn,' минимальный=',a[imn]:0:1);
  33. writeln('Номер максимального=',imx,' максимальный=',a[imx]:0:1);
  34. if abs(imn-imx)=1 then writeln('Между минимальным и максимальным нет элементов')
  35. else
  36.  begin
  37.   if imx<imn then
  38.    begin
  39.     k:=imn;
  40.     imn:=imx;
  41.     imx:=k;
  42.    end;
  43.   p:=1;
  44.   for i:=imn+1 to imx-1 do
  45.   p:=p*a[i];
  46.   writeln('Произведение элементов между минимальным и максимальным элементами=',p:0:1);
  47.  end;
  48. for i:=1 to n-1 do
  49. for j:=i+1 to n do
  50. if a[i]>a[j] then
  51.  begin
  52.   x:=a[i];
  53.   a[i]:=a[j];
  54.   a[j]:=x;
  55.  end;
  56. writeln('Отсортированный массив');
  57. for i:=1 to n do
  58. write(a[i]:5:1);
  59. readln
  60. end.

Объяснение кода листинга программы

  1. Объявление переменных:
    • n, i, j, k, imn, imx: byte;
    • s, p, x: real;
    • a: array[1..nmax] of real;
  2. Ввод размера массива n.
  3. Заполнение массива a случайными числами.
  4. Вывод исходного массива.
  5. Вычисление суммы отрицательных чисел и вывод её.
  6. Нахождение индексов минимального и максимального элемента массива.
  7. Проверка наличия элементов между минимальным и максимальным.
  8. Если между минимальным и максимальным нет элементов, то выводится сообщение.
  9. В противном случае, вычисляется произведение элементов между минимальным и максимальным.
  10. Сортировка массива методом пузырька.
  11. Вывод отсортированного массива.

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

12   голосов , оценка 3.75 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы