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

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

 

Бей­сикPython

DIM S, N AS INTEGER

S = 600

N = 10

WHILE S + 2*N >= 320

S = S − 50

N = N + 10

WEND

PRINT S

s = 600

n = 10

while s + 2*n >= 320:

    s = s − 50

    n = n + 10

print(s)

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

var s, n: integer;

begin

    s := 600;

    n := 10;

    while s + 2*n >= 320 do

    begin

        s := s − 50;

        n := n + 10;

    end;

    writeln(s)

end.

алг

нач

    цел s, n

    s := 600

    n := 10

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

        s := s − 50

        n := n + 10

    кц

    вывод s

кон

Си++

#include <iostream>

using namespace std;

int main()

{

    int s = 600, n = 10;

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

        s = s − 50;

        n = n + 10;

    }

    cout << s;

    return 0;

}

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

Ре­ше­ние.

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

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

Решим не­ра­вен­ство: 620 − x < 320. Цикл оста­но­вит­ся, когда x будет боль­ше 300. По­это­му будет 11 ите­ра­ций (300 : 30  =  10).

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

 

Ответ: 50.

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