Задания
Версия для печати и копирования в MS Word

На­пи­ши­те в от­ве­те число, ко­то­рое будет на­пе­ча­та­но в ре­зуль­та­те вы­пол­не­ния сле­ду­ю­ще­го ал­го­рит­ма (для Ва­ше­го удоб­ства ал­го­ритм пред­став­лен на пяти язы­ках).

 

Бей­сикПас­каль

DIM A, B, T, M, R AS INTEGER

A = -10: B = 31

M = A: R = F(А)

FOR T = A TO B

    IF F(T) > R THEN

        M = T

        R = F(T)

    END IF

NEXT T

PRINT M

    FUNCTION F(x)

        F = 2*(x*x-1)*(x*x-1)+17

    END FUNCTION

var a,b,t,M,R :integer;

Function

F(x:integer):integer;

    begin

    F := 2*(x*x-1)*(x*x-1)+17

    end;

begin

    a := -10; b := 31;

    M := a; R := F(a);

    for t := a to b do begin

        if (F(t) > R) then begin

            M := t;

            R := F(t)

        end

    end;

    write(M)

end.

Си++Ал­го­рит­ми­че­ский

#include <iostream>

using namespace std;

int F(int x)

{

    return 2*(x*x-1)*(x*x-1)+17;

}

int main()

{

    int a, b, t, M, R;

    a = -10; b = 31;

    M = a; R = F(a);

    for (t = a; t <= b; t++) {

        if (F(t) > R) {

            M = t; R = F(t);

        }

    }

    cout « M « endl;

}

алг

нач

цел a, b, t, M, R

a := -10; b := 31

M := a; R := F(a)

нц для t от a до b

    если F(t) > R

        то M := t; R := F(t)

    все

кц

вывод M

кон

алг цел F(цел x)

нач

    знач:=2*(x*x-1)*(x*x-1)+17

кон

Python

def f(x):

    return 2*(x*x-1)*(x*x-1)+17

a = -10

b = 31

M = a

R = f(a)

for t in range(a, b+1):

    if (f(t) > R):

        M = t

        R = f(t);

print(M)

Спрятать решение

Ре­ше­ние.

Ал­го­ритм пред­на­зна­чен для по­ис­ка наи­боль­ше­го t, при ко­то­ром функ­ция F(t) имеет наи­боль­шее зна­че­ние на от­рез­ке от a до b. Пре­об­ра­зу­ем функ­цию:

F левая круг­лая скоб­ка x пра­вая круг­лая скоб­ка =2 левая круг­лая скоб­ка x в квад­ра­те минус 1 пра­вая круг­лая скоб­ка левая круг­лая скоб­ка x в квад­ра­те минус 1 пра­вая круг­лая скоб­ка плюс 17 = 2 x в сте­пе­ни 4 минус 4 x в квад­ра­те плюс 19.

Вы­чис­лим про­из­вод­ную функ­ции:

F' левая круг­лая скоб­ка x пра­вая круг­лая скоб­ка = 8 x в кубе минус 8 x = 8x левая круг­лая скоб­ка x в квад­ра­те минус 1 пра­вая круг­лая скоб­ка =8x левая круг­лая скоб­ка x минус 1 пра­вая круг­лая скоб­ка левая круг­лая скоб­ка x плюс 1 пра­вая круг­лая скоб­ка .

Нули про­из­вод­ной: x  =  0, x  =  1, x  =  −1. Вос­поль­зу­ем­ся ме­то­дом ин­тер­ва­лов:

По­сколь­ку ал­го­ритм осу­ществ­ля­ет поиск точки t, в ко­то­рой F(t) при­ни­ма­ет наи­боль­шее зна­че­ние на от­рез­ке от −10 до 31, то пе­ре­мен­ная M будет при­ни­мать зна­че­ние 0 или 31. Под­став­ляя в функ­цию зна­че­ния 0 и 31, на­хо­дим, что наи­боль­шее зна­че­ние функ­ции до­сти­га­ет­ся в точке 31, по­это­му пе­ре­мен­ной M будет при­сво­е­но зна­че­ние 31.

 

Ответ: 31.

Источники: