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

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

 

Бей­сикPython

DIM S, N AS INTEGER

S = 600

N = 10

WHILE S + 2*N >= 400

S = S − 40

N = N + 10

WEND

PRINT S

s = 600

n = 10

while s + 2*n >= 400:

    s = s − 40

    n = n + 10

print(s)

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

var s, n: integer;

begin

    s := 600;

    n := 10;

    while s + 2*n >= 400 do

    begin

        s := s − 40;

        n := n + 10;

    end;

    writeln(s)

end.

алг

нач

    цел s, n

    s := 600

    n := 10

    нц пока s + 2*n >= 400

        s := s − 40

        n := n + 10

    кц

    вывод s

кон

Си++

#include <iostream>

using namespace std;

int main()

{

    int s = 600, n = 10;

    while (s + 2*n >= 400) {

        s = s − 40;

        n = n + 10;

    }

    cout << s;

    return 0;

}

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

Ре­ше­ние.

Цикл while вы­пол­ня­ет­ся до тех пор, пока ис­тин­но усло­вие s+2*n >= 400, т. е. сумма s и 2*n опре­де­ля­ет, сколь­ко раз вы­пол­нит­ся цикл.

За­ме­тим, что два дей­ствия s := s − 40 и n := n + 10 можно объ­еди­нить, так как цикл за­ви­сит от двух пе­ре­мен­ных. Таким об­ра­зом, на каж­дой ите­ра­ции сумма s и 2*n умень­ша­ет­ся на 20.

Решим не­ра­вен­ство: 620 − x ≥ 400. Цикл оста­но­вит­ся, когда x будет равен 240. По­это­му будет 12 ите­ра­ций (240 : 20  =  12).

Найдём, что по­лу­чит­ся на 12-ой ите­ра­ции: 600 − 40 · 12 = 120.

 

Ответ: 120.

Раздел кодификатора ФИПИ: 1.7.2 Ос­нов­ные кон­струк­ции языка про­грам­ми­ро­ва­ния. Си­сте­ма про­грам­ми­ро­ва­ния