Задания
Версия для печати и копирования в MS Word
Тип Д21 № 18502
i

Какое число будет на­пе­ча­та­но в ре­зуль­та­те ра­бо­ты сле­ду­ю­щей про­грам­мы? Для Ва­ше­го удоб­ства про­грам­ма при­ве­де­на на пяти язы­ках про­грам­ми­ро­ва­ния.

 

Бей­сикPython

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

A = -9: B = 9

M = A: R = F(A)

FOR T = A TO B

    IF F(T) <= R THEN

        M = T

        R = F(T)

    END IF

NEXT T

PRINT M+R

 

FUNCTION F(x)

    IF X>0 THEN

        F = (x-10)*(x-10) + 9

    ELSE

        F = (x-2)*(x-2) + 6

    END IF

END FUNCTION

def F(x):

    if x>0:

        return (x-10)*(x-10) + 9

    else:

        return (x-2)*(x-2) + 6

a=-9; b=9

M=a; R=F(a)

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

    if F(t) <= R:

        M=t; R=F(t)

print(M+R)

Пас­кальАл­го­рит­ми­че­ский язык

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

function F(x:integer):integer;

    begin

        if x>0

            then F := (x-10)*(x-10) + 9

            else F := (x-2)*(x-2) + 6

    end;

begin

    a := -9; b := 9;

    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+R)

end.

 

алг

нач

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

    a := -9; b := 9

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

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

        если F(t) <= R

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

        все

    кц

    вывод M+R

кон

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

нач

    если x>0

        то знач := (x-10)*(x-10) + 9

        иначе знач := (x-2)*(x-2) + 6

    все

кон

 

С++

#include <iostream>

using namespace std;

int F(int x)

{

    if (x>0)

        return (x-10)*(x-10) + 9;

    else

        return (x-2)*(x-2) + 6;

}

 

int main()

{

    int a, b, t, M, R;

    a = -9; b = 9;

    M = a; R = F(a);

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

        if (F(t) <= R) {

            M = t; R = F(t);

        }

    }

    cout << M+R;

    return 0;

}

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

Ре­ше­ние.

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

2.  При x ≤ 0 функ­ция пред­став­ля­ет собой от­ре­зок па­ра­бо­лы (x − 2)2 + 6 и на про­ме­жут­ке [−9; 0] убы­ва­ет, по­это­му ми­ни­мум до­сти­га­ет­ся на пра­вом конце от­рез­ка, то есть при x  =  0. Это зна­че­ние равно (0 − 2)2 + 6 = 10.

При x > 0 функ­ция пред­став­ля­ет собой от­ре­зок па­ра­бо­лы (x − 10)2 + 10 и на про­ме­жут­ке [0; 9] убы­ва­ет, по­это­му ми­ни­мум до­сти­га­ет­ся на пра­вом конце от­рез­ка, то есть при x  =  9. Это зна­че­ние равно (9 − 10)2 + 9 = 10. По­сколь­ку в усло­вии при­сво­е­ния зна­че­ния функ­ции стоит знак «≤» (if F(t) <= R), про­грам­ма вы­ве­дет ре­зуль­тат для точки 9. Скла­ды­вая зна­че­ния 9 и 10 по­лу­ча­ем ответ 19.

 

Ответ: 19.


Аналоги к заданию № 18502: 18633 Все