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

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

 

Бей­сикPython

DIM S, N AS INTEGER

INPUT S

N = 36

WHILE S < 2020

    S = S * 2

    N = N + 3

WEND

PRINT N

s = int(input())

n = 36

while s < 2020:

    s = s * 2

    n = n + 3

print(n)

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

var s, n: integer;

begin

    readln(s);

    n := 36;

    while s < 2020 do

    begin

        s := s * 2;

        n := n + 3

    end;

    writeln(n)

end.

алг

нач

    цел n, s

    ввод s

    n := 36

    нц пока s < 2020

        s := s * 2

        n := n + 3

    кц

    вывод n

кон

Си++

#include <iostream>

using namespace std;

int main()

{

int s;

cin >> s;

int n = 36;

    while (s < 2020) { s = s * 2; n = n + 3; }

    cout << n << endl;

    return 0;

}

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

Ре­ше­ние.

За­ме­тим, что чтобы про­грам­ма вы­ве­ла число 60, к числу N  =  36 долж­но при­ба­вить­ся 24, т. е. цикл дол­жен вы­пол­нить­ся 8 раз. По­сколь­ку в каж­дой ите­ра­ции цикла число s умно­жа­ет­ся на 2, будем рас­смат­ри­вать сте­пе­ни двой­ки. Бли­жай­шее число, боль­шее 2020 и яв­ля­ю­ще­е­ся 2 в n-ной сте­пе­ни  — 2048  =  211. Зна­чит, наи­мень­шее воз­мож­ное вход­ное число s  — 23  =  8.

 

Ответ: 8.

 

При­ведём дру­гое ре­ше­ние на языке Python.

for i in range(1, 10000):

s = i

n = 36

while s < 2020:

s = s * 2

n = n + 3

if n == 60:

print(i)

break

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