Найти суммы максимального и минимального значений функции и их аргументов - Turbo Pascal

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

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

Используя функцию F, построить массив y с элементами yk=F(k). Выполнить для этого массива следующий поиск данных: F:=cos(sqr(x+1)-ABS(sin(2*x)-5.76). Найти суммы максимального и минимального значений функции и их аргументов.

Решение задачи: «Найти суммы максимального и минимального значений функции и их аргументов»

textual
Листинг программы
  1. uses crt;
  2. const nmax=100;
  3. var y:array[1..nmax] of real;
  4.     n,k,kmn,kmx:byte;
  5. begin
  6. clrscr;
  7. randomize;
  8. repeat
  9. write('Размер массива Y от 2 до ',nmax,' n=');
  10. readln(n);
  11. until n in [2..nmax];
  12. writeln('Массив Y');
  13. for k:=1 to n do
  14.  begin
  15.   y[k]:=cos(sqr(k+1)-abs(sin(2*k))-5.76);
  16.   write(y[k]:8:2);
  17.   if k=1 then
  18.    begin
  19.     kmn:=1;
  20.     kmx:=1;
  21.    end
  22.   else if y[k]<y[kmn] then kmn:=k
  23.   else if y[k]>y[kmx] then kmx:=k
  24.  end;
  25. writeln;
  26. writeln('Минимальное значение функции=',y[kmn]:0:2,' аргумент=',kmn);
  27. writeln('Максимальное значение функции=',y[kmx]:0:2,' аргумент=',kmx);
  28. writeln('Сумма значений=',y[kmn]+y[kmx]:0:2,' сумма аргументов=',kmn+kmx);
  29. readln
  30. end.

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

  1. В начале кода подключается библиотека crt, которая обеспечивает работу с консолью.
  2. Затем определяется константа nmax, которая ограничивает размер массива y до 100 элементов.
  3. Создается переменная y типа array[1..nmax] of real, которая представляет собой массив для хранения значений функции.
  4. Определяются три байтовых переменные n, k и kmn, которые будут использоваться для отслеживания текущего, минимального и максимального значений функции соответственно.
  5. Запускается цикл repeat, который продолжается до тех пор, пока размер массива y не будет в диапазоне от 2 до nmax.
  6. Внутри цикла запрашивается у пользователя размер массива y и выводится сообщение с этим размером.
  7. Затем выводится сообщение о содержимом массива y.
  8. Запускается цикл for, который проходит по всем элементам массива y от k=1 до n.
  9. Внутри цикла вычисляется значение y[k] с помощью функции cos, квадратизирующей k+1, абсолютного значения sin(2*k)) и добавленного сдвига -5.76.
  10. Выводится значение y[k] с точностью до 8 знаков после запятой.
  11. Если k=1 (т.е. это первый элемент массива), то устанавливаются минимальное и максимальное значения функции и их аргументы kmn и kmx соответственно.
  12. Если y[k] меньше y[kmn], то kmn устанавливается равным k.
  13. Если y[k] больше y[kmx], то kmx устанавливается равным k.
  14. После завершения цикла выводятся сообщения с минимальным и максимальным значениями функции и их аргументами.
  15. Вычисляется сумма значений y[kmn] и y[kmx], а также сумма аргументов kmn и kmx.
  16. Конец программы.

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


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

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

9   голосов , оценка 3.778 из 5

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

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

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